登录注册
论坛
一粒金砂(初级)
1
0
扫一扫,分享给好友
纯净的硅(初级)
547
裸片初长成(中级)
7815
56
强者为尊,弱者,死无葬身之地
一粒金砂(中级)
二进制小数的存储是对于大多数小数来说是一个趋近数。
精度跟你表示数值的范围有关,详细的精度大小可以参照C语言程序设计里数据类型对浮点数一章的描述。
其实精度没你说的那么差,我认为你所说的0.01是因为你检测方法有误导致认为精度就是这个。
譬如一个1.56的数值,浮点数存储之后是也许是 1.5600001,但也有可能是1.5599999,当你把数据取整用来显示的时候,你会取2位有效数字,可想而知,如果存储结果是第一种情况,那么你读到的数值是1.56,如是第二种你读到的结果是1.55,所以你理所当然的认为精度是0.01。
其实关于这个显示精度,我觉得比较好是做法就是,当你显示的精度需求是0.01时,你可以让浮点数加上0.001之后再取整,那么就是你想要是数字啦。但当你只是需要浮点数运算的时候,大可不必如此。
五彩晶圆(中级)
2130
发表回复 回帖后跳转到最后一页
曾经的版主且威望大于2000,或对EEWORLD论坛有突出贡献的坛友
EEWorld Datasheet 技术支持
查看 »