1 问题引入
经常需要将一种数值类型转换为另一种数值类型;
例如1+3.72—>整型+浮点型。结果为4.72没问题,可是会有一些精度的问题。
2 查看问题
请看以下代码:
int n = 987654321;
float f = n;
此时f的值为9.8765434E8
就已经对精度没那么准确了。
所以统计了一下数值类型之间的合法转换:
因为两个类型相加,先将两个操作数据转换为同一种类型,转换时总会比变成大容量的一方,所以图中是单向箭头。
黑色箭头表示无信息丢失转换。
红色箭头标识可能有精度损失转换。(就像上方的例子)。
3 注意事项
如果两个操作数中有一个是 double 类型,另一个操作数就会转换为 double 类型
否则,如果其中一个操作数是 float 类型,另一个操作数将会转换为 float 类型
否则,如果其中一个操作数是 long 类型,另一个操作数将会转换为 long 类型。
否则,两个操作数都将被转换为 int 类型。
上面只会由小->大转换,那么大->小转换如何呢,可以看一下强制类型转换。