java – 关于float类型的精度

前端之家收集整理的这篇文章主要介绍了java – 关于float类型的精度前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我无法理解为什么会这样
float f = Integer.MAX_VALUE;
System.out.println(Integer.MAX_VALUE);
System.out.println((int)f);

产生相同的线,

以及为什么这样做

Float f2 = (float) Integer.MAX_VALUE;
System.out.println(Integer.MAX_VALUE);
System.out.println(f2.intValue());

我的意思是,浮点数的尾数长度是2 ^ 23-1.它如何设法保持整数的max_value,即2 ^ 31 – 1?

解决方法

How does it manage to keep max_value of integer,which is 2^31 – 1?

它实际上没有. f的值是2147483648.

但是,narrowing primitive conversion从float到int钳位该值.它到达这一部分:

  • Otherwise,one of the following two cases must be true:

    • The value must be too small (a negative value of large magnitude or negative infinity),and the result of the first step is the smallest representable value of type int or long.

    • The value must be too large (a positive value of large magnitude or positive infinity),and the result of the first step is the largest representable value of type int or long.

通过使数字更大,您可以轻松地看到这一点:

float f = Integer.MAX_VALUE;
f = f * 1000;
System.out.println(Integer.MAX_VALUE); // 2147483647
System.out.println((int)f); // 2147483647

或者通过铸造来代替,显然不需要在同一点夹紧:

float f = Integer.MAX_VALUE;
System.out.println(Integer.MAX_VALUE); // 2147483647
System.out.println((long)f); // 2147483648

猜你在找的Java相关文章