C++浮点数的机器码表示

C++的double类型是用64位二进制数存储的,对于一个double类型的数,机器先将该数转换为二进制数,然后进行规格化处理,将小数点移到最左边的1后面,计算小数点的移位数N,阶码就是N+1023,1023(十进制)-3FFh(十六进制)--(1111111111)(二进制)10个1,然后用52位存储规格化后的小数点后面的52位二进制数。符号位根据正负设置。

   如:double a=12345.67891023456;

   123456.67891023456转化为二进数是11000000111001.101011011100110100001111101001100101101,规格化处理,小数点要移13位,阶码是13+1023,用11位二进制数表示为 “10000001100”,保存小数点后的52位二进制数,那么机器码就是 0  -  10000001100  -  1000000111001101011011100110100001111101001100101101

                                                                       符号位        阶码                                             尾数

 

从新转化为十进制数,先将1.1000000111001101011011100110100001111101001100101101转为十进制数1.507040882596992,阶码减回1023得13,

1.507040882596992 * 2 ^13=12345.67891023456;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值