我们知道java中的各个数据类型的取值范围不同,可以理解成容量大小,而针对容量大小可以对他们进行一个由低到高的排序,也就是优先级。
低-----------------------------------------------------------------------高
(byte,short,char)=> int => long => float => double
类型之间的转换形式有两种,一种的是强制转换,另外一种是自动转换(也叫类型提升)。
首先我们看,把优先级高的数据类型赋值给优先级低的数据类型是不被允许的。
这种情况我们要用到强制类型装转换,即在变量名前加上想要转换的类型即可。
但是强制类型转换可能会出现内存溢出,或者精度问题。如下:
我们可以看到打印结果是-24,并不是1000。因为byte类型的取值范围是-128 ~ 127,很显然1000已经远远大于了这个范围,所以导致结果内存溢出,结果并不是我们想要的。如果刚刚 i 的值没有超出byte的取值范围,则强制类型转换后不会出现刚刚的内存溢出情况,转换后的值不会变化。
当我们把优先级小的数据类型赋给优先级大的数据类型则不用去进行类型转换,java会出现自动类型提升且不会存在内存溢出的问题。
我们来看一个例子
很显然打印的结果出现了问题,也就是说类型没有自动提升而导致内存溢出,结果不正常。
原因:
当int类型的x与int类型的y进行运算时,得到的值还是int类型,但是这个时候x*y的值已经超过了int类型的取值范围,所以x乘y的结果就已经是内存溢出,变成负数了。然后int类型赋值给long类型,自动类型转换,值不变。
解决办法:
只要在运算时将一个int类型转换为long类型,这样x与y在运算时会自动类型提升,变成两个long类型做运算。
可以看到,结果没有问题。