注意
public static void main(String[] args) { //强制类型转换注意内存溢出,导致精度不准确 float f = 23.4F; double d = 45.32; System.out.println("f = "+(int)f); System.out.println("d = "+(int)d);
执行结果:
//最好完全避免使用浮点数进行比较,存在舍入误差。 float a = 3.2F; double b = 3.2; System.out.println("=============================="); System.out.println(a); System.out.println(b); System.out.println(a == b);
执行结果:
输出结果值相同,但是比较值为false,说明存在舍入误差,尽量不使用float进行比较。
//算术运算之后出现内存溢出,需要在运算前进行强制转换 int i = 10_0000_0000; int j = 20; long m = i*(long)j; System.out.println("=============================="); System.out.println(i*j); System.out.println(m);
执行结果:
数值过大的数据在运算之后强制转换得到的数值不正确,出现内存溢出,需要在运算前进行数据类型转换。