java – 从double转换为int并不总是只是放弃小数部分

前端之家收集整理的这篇文章主要介绍了java – 从double转换为int并不总是只是放弃小数部分前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在试验我在这里找到的代码 The Java Specialists’ Newsletter.
public class MeaningOfLife {
  public static String findOutWhatLifeIsAllAbout() {
  int meaning = 0;
  for (int i = 0; i < 10; i++) {
    for (int j = 0; j < 20; j++) {
      for (int k = 0; k < 300; k++) {
        for (int m = 0; m < 7000; m++) {
          meaning += Math.random() + 1;
        }
      }
    }
  }
  return String.valueOf(meaning).replaceAll("0*$","");
  }

public static void main(String[] args) {
  System.out.println(findOutWhatLifeIsAllAbout());
}
}

问题“打印什么”的答案似乎很明显,一旦我意识到有一个隐含的演员与compound assignment operator =.

但是它打印出如:420000006或420000007,
而不是(预期)420000000(或“42”,删除尾随零).

所以这表明从double到int的转换不总是只是放弃双倍的小数部分,如这里所述:How to cast a double to an int in Java?

所以我做了一些试验,这里是我发现的一个例子:

System.out.println((int)  (131070.99999999999)); // -> 131070
System.out.println((int)  (131071.99999999999)); // -> 131071
System.out.println((int)  (131072.99999999999)); // -> 131073 !!!
System.out.println((int)  (131073.99999999999)); // -> 131074 !!!


System.out.println((int)  (16382.999999999999)); // -> 16382
System.out.println((int)  (16383.999999999999)); // -> 16383
System.out.println((int)  (16384.999999999999)); // -> 16385 !!!
System.out.println((int)  (16385.999999999999)); // -> 16386 !!!

那么现在我正在寻找一个解释这个行为?

解决方法

也许你会惊讶于这样的事实
System.out.println(131072.99999999999); // -> 131073 !!!

你不必将事件转换成int.

在Java(和其他语言)中也有双重表示的问题.系统不像人类那样使用’decimal’部分.

这里有很长的解释:
http://en.wikipedia.org/wiki/Floating_point

但简而言之,双重值就是存储少部分的东西来获得最终的结果(像-1.23 * 10 ^ -15).而且,对于这些给定的数字,您的空间只能有限.所以最后你不能完全代表Double.MAX_VALUE和Double.MIN_VALUE中的每个数字.

猜你在找的Java相关文章