黑马程序员技术交流社区

标题: 为什么会出现下面的情况 [打印本页]

作者: 途中ms前进    时间: 2015-5-26 13:06
标题: 为什么会出现下面的情况
class Test2
{
        public static void main(String[] args)
        {
                double a=0.01,b=0.09;
                System.out.println(a+b);
       
        }
        }为什么打印结果是0.09999999999999999而不是0.1
作者: 791180016    时间: 2015-5-26 15:58
任何一门语言对于浮点数的计算都是不精确的。因为现在的PC都是基于二进制数来存储计算的,而对于浮点数计算有时就会产生误差。因为有的浮点数转换成为二进制时是一个无穷循环小数。例如十进制的0.4,转换成为二进制为0.0110011001100110....,这样,在0.4+0.3时就不能准确的算出是0.7,而是经过一些舍入处理才能得出正确结果,但经过多次运算误差产生的较大时,即使经过一些舍入处理也不能得到精确的结果了。
作者: zhousuo28    时间: 2015-5-27 15:55
因为计算机底层运算是用2进制,运算时会损失精度,如果要进行高精度运算可以用Math类四则运算




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2