linux C 下定义float 52.1 输出怎么是52.099999

linux C 下定义float 52.1 输出怎么是52.099999,第1张

很正常,这和浮点数在计算机中的表示有关!

浮点数在计算机中是采用二进制科学计数法存储的。

一、浮点数转换成二进制

52.1=110100.0001100110011(小数部分不能完全转换)

二、表示成二进制科学计数法

1.101000001100110011 * 2^5

三、按IEEE754进行数据存储

因此,再将内存中的数据转换成十进制输出来的数据不是完整的52.1,只是非常接近它。

sort -g可以识别

-g, --general-numeric-sort compare according to general numerical value


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8535221.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存