gpt4 book ai didi

c++ - 将双常量定义为十六进制?

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:10:24 24 4
gpt4 key购买 nike

我希望将最接近 1.0 的数字作为 float 。通过阅读维基百科关于 IEEE-754 的文章我设法发现 1.0 的二进制表示形式是 3FF0000000000000,因此最接近的 double 值实际上是 0x3FEFFFFFFFFFFFFFF

我知道用这个二进制数据初始化 double 的唯一方法是:

double a;
*((unsigned*)(&a) + 1) = 0x3FEFFFFF;
*((unsigned*)(&a) + 0) = 0xFFFFFFFF;

使用起来比较麻烦。

如果可能的话,是否有更好的方法来定义这个双数?

最佳答案

十六进制 float 和 double 文字确实存在。语法为 0x1.(尾数)p(十进制指数)在你的情况下,语法是

double x = 0x1.fffffffffffffp-1

关于c++ - 将双常量定义为十六进制?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3947159/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com