一直都知道double的存储格式是IEEE制定的标准,但是从来没有看到C++中double是怎么存的。
今天突发奇想,想看看double在C++是怎么存储的。找了很久发现可以用union轻松的完成。
union Double2Int { double d; unsigned __int64 i; };
根据union的特性,这样就可以轻松的看到double是怎么存储的。
但是,想要输出的时候又要费一番功夫。原因是%x只支持32位的十六进制输出。
输出64位十六进制需要用到%llx。
最后给出,测试代码。
#include <stdio.h> union Double2Int { double d; unsigned __int64 i; }; int main() { Double2Int d2i; d2i.d = -1; printf("double : %lf\tHex : %llx\n", d2i.d, d2i.i); return 0; }
时间: 2024-08-06 20:03:20