gpt4 book ai didi

c++ - 从长位加倍

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

我有一个 unsigned long long(或 uint64_t)值,想将其转换为 double。 double 应具有与 long 值相同的位模式。这样我就可以“手动”设置 double 的位。

unsigned long long bits = 1ULL;
double result = /* some magic here */ bits;

我正在寻找一种方法来做到这一点。

最佳答案

执行此操作的可移植方法是使用 memcpy(您也可以有条件地使用 reinterpret_cast 或 union 来执行此操作,但这些不一定是可移植,因为它们违反了严格别名规则的字面意思):

// First, static assert that the sizes are the same
memcpy(&result, &bits, sizeof(bits));

但在你这样做之前,请确保你确切地知道你在做什么以及正在使用什么浮点表示法(尽管 IEEE754 是一种流行/常见的选择)。您需要避免各种问题值,例如无穷大、NaN 和非正规数。

关于c++ - 从长位加倍,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17409162/

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