浮点运算误差
今天一哥们遇到个很诡异的事情,3个 0.15的 dobule数相加竟然不等于0.45. 学习了之后才知道这是由于浮点运算的误差所致。看来基础课没学好啊。
还有些小例子:
[Java Code]下面这个简单的计算将得到 2.600000000000001
,而不是 2.6
:
double s=0;
for (int i=0; i<26; i++)
s += 0.1;
System.out.println(s);
for (int i=0; i<26; i++)
s += 0.1;
System.out.println(s);
这篇文章说的非常详细:http://www.ibm.com/developerworks/cn/java/j-jtp0114/index.html