问: float f=3.4;是否正确?
答: 不正确。3.4是双精度数,将双精度型(double)赋值给浮点型(float)属于下转型(down-casting,也称为窄化)会造成精度损失,
因此需要强制类型转换float f =(float)3.4; 或者写成float f =3.4F;。
拓展:
在java里面,没小数点的默认是int,有小数点的默认是 double;
byte、short、int、long、float、double
向上转型会自动进行 float a = 1; 运行结果是1.0
向下转型需要强制转换 float a = (float)3.4; int a = (int) 11.1;
隐含的强制类型转换:
问:
short s1 = 1; s1 = s1 + 1;有错吗?short s1 = 1; s1 += 1;有错吗?
答:
对于short s1 = 1; s1 = s1 + 1;
由于1是int类型,因此s1+1运算结果也是int 型,需要强制转换类型才能赋值给short型。
而short s1 = 1; s1 += 1;可以正确编译,因为s1+= 1; 相当于s1 = (short)(s1 + 1); 其中有隐含的强制类型转换。