c语言中3 10等于,为什么10/3它在C中是准确的?

dbush..

8

你最终得到的结果恰好是10,因为表示恰好是这样的.我对float和double的实现都是一样的.

让我们看一个使用double的例子:

如果我们10./3.使用十六进制浮点表示法打印出来%a,我们得到:

0x1.aaaaaaaaaaaabp+1

这与IEEE754双重表示相匹配0x401aaaaaaaaaaaab.

以上数字归一化为:

0x3.5555555555558

二进制:

11.0101010101010101010101010101010101010101010101011

为了简单起见,让我们添加三次而不是乘以3:

11.0101010101010101010101010101010101010101010101011

+ 11.0101010101010101010101010101010101010101010101011

---------------------------------------------------------

110.1010101010101010101010101010101010101010101010111

+ 11.0101010101010101010101010101010101010101010101011

---------------------------------------------------------

1010.0000000000000000000000000000000000000000000000000

这正好是10.

编辑:

看起来我设法在最后几位数字处理数学.实际总和:

11.0101010101010101010101010101010101010101010101011

+ 11.0101010101010101010101010101010101010101010101011

---------------------------------------------------------

110.1010101010101010101010101010101010101010101010110

+ 11.0101010101010101010101010101010101010101010101011

---------------------------------------------------------

1010.0000000000000000000000000000000000000000000000001

所以它不完全是 10,而是最不重要的一点.

我注意到使用float时有类似的区别.

10.f/3.f印有%a:

0x1.aaaaaap+1

标准化:

0x3.555554

二进制:

11.0101010101010101010101

然后我们添加:

11.0101010101010101010101

+ 11.0101010101010101010101

------------------------------

110.1010101010101010101010

+ 11.0101010101010101010101

------------------------------

1001.1111111111111111111111

再次,由最不重要的位.

至于实际结果如何四舍五入,我不能说.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值