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

© fengche 中级黑马   /  2013-10-16 11:41  /  1606 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 fengche 于 2013-10-17 13:25 编辑

public class Change{
        public static void main(String args[]){
                System.out.println(2.00 - 1.10);
        }
}
打印的是0.8999999999999999
从网上看到的 求黑马大神解释?

评分

参与人数 1技术分 +1 收起 理由
李江 + 1

查看全部评分

5 个回复

倒序浏览
菜鸟一个...
因为是浮点运算,浮点运算采用补码规则,得到的结果不精确
回复 使用道具 举报
float和double只能用来做科学计算或者是工程计算,在商业计算中我们要用java.math.BigDecimal。float和double有默认的精确位数。
回复 使用道具 举报
LZ没有定义数据类型 如果带小数点 默认的都是double双精度浮点型。
double i = 2.00;
double j = 1.10;
System.out.println(i-j);
至于结果 出现这种问题的原因是浮点数值是采用二进制系统表示的,而在系统中无法精确的表示分数1/10
有的时候损失点精度也是正常的 也不必过于纠结结果了。
如果真的想整明白,那就去好好的学学java编程的底层代码吧。

评分

参与人数 1技术分 +1 收起 理由
To + 1 很给力!

查看全部评分

回复 使用道具 举报
问题解决后,麻烦楼主把帖子状态改为提问结束...谢谢配合工作...
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马