一直都知道double的存储格式是IEEE制定的标准,但是从来没有看到C++中double是怎么存的。
今天突发奇想,想看看double在C++是怎么存储的。找了很久发现可以用union轻松的完成。
union Double2Int
{
double d;
unsigned __int64 i;
};
但是,想要输出的时候又要费一番功夫。原因是%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;
}