我有一个 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/