类型转换
在运算中,将不同类型的数据转换为同一种类型的数据再进行运算。
类型的优先级由低到高分别是:
byte<short<char<int<long<float<double
我们需要注意的是,小数的优先级大于整数。
强制转换
int a=128;
byte b=(byte)a;
这两行中,因为b只能表达-128到127之间的数字,我们强制转化过来后得到的值就是-128
这其中有一个内存溢出的问题,内存溢出后所得到的值和我们本身的值是不一样的,所以在转换中要避免这种问题
当然,上面代表着我们将a从int类型强制转换为byte类型
强制转换只发生在高优先级到低优先级的转换之间
自动转换
自动转换则是由低到高的转换,并不需要特意的要求
//比如
int a=128;
long b=a;
如同上面的两行,Long的优先级比int要高,所以自动的就将int类型的128变成了long类型的128。
注意问题
- 不能对boolean进行转换
- 不能转换为不相干的对象类型
- 高容量转换为低容量时,使用强制转换
- 转换时会有内存溢出和精度问题
- 在计算前就需要进行转换
//比如我们计算1000000000和20相乘
int a=10_0000_0000;
int b=20;
system.sout.println(a*b);
//如果我们直接计算就会出现内存溢出问题,所以我们需要转换成long类型
long c=a*b;//但是a和b的默认类型就是int,
//所以我们要在计算过程中就转换掉:
long d=(long)a*b;//这样就是成功将计算的结果转换为了long类型
system.sout.println(c)
//再输出我们就会发现是200_0000_0000