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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 罗冠坤 中级黑马   /  2014-3-16 22:59  /  1215 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

书中写到当以下表达式会出现丢失精度的问题:
float result = 0.0f;
long a = 64400;
const float b = 4.5f;

丢失精度的表达式:result = a / 150 * b;       这个计算结果为1930.50
改后的表达式:result = b * a / 150;  书中说改成这个样子就不会发生精度丢失,计算结果为1932

谁能解释解释这是为什么呢?
两个表达式只是更换了运算的顺序,为什么结果就不一样了呢?

评分

参与人数 1技术分 +1 收起 理由
jing迪 + 1

查看全部评分

3 个回复

倒序浏览
运算符的优先级为同一级别的由左至右运算。
回复 使用道具 举报
恩恩,刚查过了,上面的其实是一个隐式转换
第二个之所以运算没有丢失精度,是因为在进行long→float的隐式转换
所以保留了小数位数,没有进行四舍五入。现在明白啦。。。
回复 使用道具 举报
解析:
float result = 0.0f;
long a = 64400;
const float b = 4.5f;

==1.a/150=429,429*4.5=1930.5

==2.a*b=289800, 289800/150=1932;

由于a/150丢失了小数部分,所有导致最后的结构不一致
不过这些都是由于运算符的优先级问题,还有同等优先级的从左到右进行运算,
像这样的运算,最好是加上括号即可。

评分

参与人数 1技术分 +1 收起 理由
jing迪 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马