关于C++ printf()函数的一点疑问
伊谢尔伦
伊谢尔伦 2017-04-17 12:08:39
0
1
517

初学C++,对于printf()函数的精度指示符有一点疑问。

因为之前学过其他语言,所以在解决四舍五入的问题的时候使用了printf()函数,但是发现:

float x=20.095;
printf("%.2f",x);

这样输出的是20.09,而不是正常四舍五入的20.10。
但如果是另一种情况:

float x=20.085;
printf("%.2f",x);

20.09就能够正常的输出

请教一下,这是因为什么原因导致的?搜索了一下没有找到相关的说明,书上也没有具体解释。
如果想要正常的四舍五入,对于初学者,比较简单的解决方案是什么?
谢谢!

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回覆(1)
刘奇

不是printf()的問題,是精確度問題,20.085在電腦記憶體中並不是精確的,實際上這個值無法用二進位精確表示。它的小數部分的前面幾十位是0.00010101110000101000111101011100001010001111011,早已超出float的精度了。所以會以近似值存儲,不巧的是,這個近似值比20.085要小一點點,所以四捨五入的時候自然就會被捨掉了。
可以看看這篇文章:http://www.cnblogs.com/antineutrino/p/4525224.html

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!