您现在的位置是:网站首页 -> 代码相关 文章内容
double与uint64互转精度丢失-itarticl.cc-IT技术类文章记录&分享
发布时间: 8年前【代码相关】 116人已围观【返回】
1. double:
1bit(符号位) 11bits(指数位) 52bits(尾数位)
浮点数的十进制形式是,即十进制的科学计数法: a.xxx *10^n,
而在计算机中是用二进制的科学计数法表示:1.xxx * 2^n(*是二进制乘法 即移位)
指数位用来表示了n,尾数位表示的是小数部分xxx。
比如 8.25 ,二进制 100.01 ->1.0001*2^2
而指数有正负,所以double型最大值是2^1024 = 1.79E+308 ,比64位uint64_t 要大多了 ,这是因为损失了数据精度的:
uint64_t最大值转为double型:64bit的1->1.111(52个)*2^63 (在vs中实际转换后表示成了1.00*2^64,应该是因为最后11个bit 进了一位),
而完整无损失的表示应该是:1.111(52个)111(11个)*2^63
因为double的尾数只有52bit,所以后面的11bit的1是损失了的,整数 (1<<64)-1 到 (1<<64)-1 -( (1<<11) -1) 转换成double时是一样的结果
(vs调试中考虑了四舍五入,(1<<64)-1 到 (1<<64)-1 -( (1<<10) -1 转换结果一样)
也就是说64bit的整数,用double表示,(考虑四舍五入)误差可达1023(即double的分辨率只有1023,或许double a 与 a+1023 相等)
63bit 误差可达511 .... ,54bit误差可达1,不超过53bit时,用double表示才没有误差。
发布时间: 8年前【代码相关】116人已围观【返回】【回到顶端】
很赞哦! (1)
相关文章
点击排行

站长推荐

猜你喜欢
站点信息
- 建站时间:2016-04-01
- 文章统计:728条
- 文章评论:82条
- QQ群二维码:扫描二维码,互相交流
