我希望将 1.0 以下最接近的数字作为浮点数。通过阅读维基百科的文章IEEE-754 http://en.wikipedia.org/wiki/IEEE_754-1985#Double-precision_64_bit我设法发现 1.0 的二进制表示是3FF0000000000000
,所以最接近的双精度值实际上是0x3FEFFFFFFFFFFFFF
.
我知道用这个二进制数据初始化双精度的唯一方法是:
double a;
*((unsigned*)(&a) + 1) = 0x3FEFFFFF;
*((unsigned*)(&a) + 0) = 0xFFFFFFFF;
使用起来比较麻烦。
如果可能的话,是否有更好的方法来定义这个双精度数?
十六进制浮点和双精度确实存在。
语法为 0x1.(尾数)p(十进制指数)
在你的情况下,语法是
double x = 0x1.fffffffffffffp-1
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)