C ++ Double to Binary表示(重新解释转换)

时间:2015-07-04 18:36:04

标签: c++ pointers char endianness reinterpret-cast

我最近决定创建一个程序,允许我在C ++中打印出任何类型实例的确切位模式。我从原始的内置类型开始。我打印了打印double类型的二进制表示的问题。

这是我的代码:

#include <iostream>
using namespace std;

void toBinary(ostream& o, char a)
{
    const size_t size = sizeof(a) * 8;
    for (int i = size - 1; i >= 0; --i){
        bool b = a & (1UL << i);
        o << b;
    }
}

void toBinary(ostream& o, double d)
{
    const size_t size = sizeof(d);
    for (int i = 0; i < size; ++i){
        char* c = reinterpret_cast<char*>(&d) + i;
        toBinary(o, *c);
    }
}

int main()
{
    int a = 5;
    cout << a << " as binary: "; 
    toBinary(cout, static_cast<char>(a));
    cout << "\n";

    double d = 5;
    cout << d << " as double binary: ";
    toBinary(cout, d);
    cout << "\n";
}

我的输出如下: 5为二进制:00000101

5作为双二进制:000000000000000000000000000000000000000000000000000000001010001000000

但是,我知道5作为浮点表示是: 01000000 00010100 00000000 00000000 00000000 00000000 00000000 00000000

也许我在这里不理解某些内容,但我写的reinterpret_cast<char*>(&d) + i行没有允许我将double*视为char*因此,向其添加i会使指针前进sizeof(char)而不是sizeof(double)。 (这是我想要的)?我做错了什么?

1 个答案:

答案 0 :(得分:1)

如果将数字类型解释为“字节序列”,则会暴露给机器字节序:某些平台首先存储最高有效字节,其他平台则反向存储。

只需观察你的数字,在8位组中,将它从最后一组读到第一组,你就能得到你期望的结果。

请注意,整数也会出现同样的问题:5(32位)是

00000101-00000000-00000000-00000000 

而不是

00000000-00000000-00000000-00000101 

正如你所期待的那样。