今天一哥们遇到个很诡异的事情,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