为了账号安全,请及时绑定邮箱和手机立即绑定

为什么在java中 2.0-1.1=0.899999... 但是2.0-0.1却可以=1.9?

为什么在java中 2.0-1.1=0.899999... 但是2.0-0.1却可以=1.9?

暮色呼如 2019-04-17 17:15:57
已经了解过1.1和0.1的二进制转换,但是0.1和1.1一样小数部分在二进制中同样是无法表现完全的,为何2.0-0.1可以表现清楚???
查看完整描述

4 回答

?
泛舟湖上清波郎朗

TA贡献1818条经验 获得超3个赞

用10进制打一个比方,有一个10进制存储的浮点数,可以保持4位尾数
50/11和16/11分别是4.5455和1.4545,前者因为后面的尾数5所以导致了进位,对吧
二进制也是一样
0.1(dec) = 0.0001100110011001100...(bin)
那么要看尾数最后一位是多少,如果卡到00上面,那么舍去的比较多,就会出现9999,如果卡在11,舍去的比较少,就正好是1,9了
明白了么

查看完整回答
反对 回复 2019-05-16
?
胡子哥哥

TA贡献1825条经验 获得超6个赞

0.0问题看错了,我也试了下,真的诶,好奇怪


查看完整回答
反对 回复 2019-05-16
?
不负相思意

TA贡献1777条经验 获得超10个赞

计算机上的浮点类型会产生一定的精度误差


查看完整回答
反对 回复 2019-05-16
?
狐的传说

TA贡献1804条经验 获得超3个赞

https://img1.sycdn.imooc.com//5cdd0fd200015d5404960340.jpg

没有你这样的情况哦

查看完整回答
反对 回复 2019-05-16
  • weixin_慕移动6522811
    weixin_慕移动6522811
    public static void main(String[] args) { float a = 2.0f - 1.9f; System.out.println(a); } 你这样写试试看。
  • 4 回答
  • 0 关注
  • 1161 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号