Java之间的数值转换如图所示,实心箭头代表无数据丢失,虚线箭头代表可能丢失
例如:123456789是一个大的整数,包含的位数比float类型能够表达的位数多,但这个数转换为float类型时,将会得到同样大小的结果,但却失去了一定的精度。
int n = 123456789;
float f =n; //f is 1.23456792E8
当转换前后两个数进行二元操作时(例如n+f,n为整数,f为浮点数),则先将两个操作数转换为同一个类型,再进行计算。
转换规则:
--如果两个操作数中有一个是double类型,另一个操作数就会转换为double类型。
--否则,如果其中一个操作数是float类型时,另一个操作数将会转换为float类型。
--否则,如果其中一个操作数是long类型时,另一个操作数将会转换为long类型。
--否则,两个操作数都将会被转换为int类型。
强制转换类型
在Java中允许进行像int转换为double类型或者double转换为int,但有可能丢失一些信息。如像强制转换类型,则需要通过强制类型转换(cast)实现。强制类型转换的语法格式是在圆括号中给出想要转换的目标类型,后面紧跟待转换的变量名<