为什么会发生数据类型转换呢?
不同数据类型的变量相互赋值时,会发生数值范围不匹配的问题,就需要类型转换。
1 类型转换的概念
类型转换的概念:把一种数据类型直接赋值给另外一种数据类型称为数据类型的转换。
2 隐式类型转换(自动类型提升)
概念:又叫做自动类型转换,系统自动把小类型转为大类型。
byte--->short--->int--->long--->float--->double
char--->int
运算过程中的隐式转换
取值范围小的数据,和取值范围大的数据进行运算,小的会先提升为大的之后,再进行运算。
byte、short、char三种数据在运算的时候,都会提升为int,然后再进行运算。
问题:float占用4个字节,long占用8个字节,为什么long在float后面?
解释:
虽然float占用4个字节,但是【取值范围】要比8个字节的long更大。
小数的二进制形式更加节省内存。
3 强制类型转换
概念:把一个取值范围大的数值或者变量,赋值给另一个取值范围小的变量。不允许直接赋值,需要加入强转。
格式:取值范围小的数据类型名 变量名 = (取值范围小的数据类型名)取值范围大的变量
注意:应该尽量避免出现强制类型转换,因为会产生精度损失,数据溢出。
9234

被折叠的 条评论
为什么被折叠?



