A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本帖最后由 江南小道士 于 2013-11-29 22:30 编辑

public static void main(String[] args)
        {
                double x = add(2.3,3.4);
                System.out.println("x="+x);
        }

        public static double add(double a,double b)
        {
                return a+b;
        }


运行结果——  x=5.699999999999999

为什么?为什么?哪位能解答一下吗?

评分

参与人数 1技术分 +1 黑马币 +6 收起 理由
枫儿 + 1 + 6 神马都是浮云

查看全部评分

2 个回复

倒序浏览
要归咎于CPU表示浮点数的方法.举个例子:2.4的二进制表示并非就是精确的2.4,而是最为接近4.199999809265137;原因在于浮点数由两部分组成:指数和尾数,浮点数的值实际上是由cpu的某个数学公式计算得到的,所以您所遇到的精度损失会在任何操作系统和编程环境中遇到。

评分

参与人数 1技术分 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

回复 使用道具 举报
HAnG 发表于 2013-11-29 17:10
要归咎于CPU表示浮点数的方法.举个例子:2.4的二进制表示并非就是精确的2.4,而是最为接近4.19999980926513 ...

谢谢,这部分好复杂,还没学到~~~
刚开始学习,只知道小数默认为double类型,double占八个八位~~~~~~
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马