为什么函数以相反的顺序显示十六进制代码?

时间:2016-02-16 04:25:33

标签: c++ endianness

以下代码(在C ++中)应该获取一些数据及其大小(以字节为单位)并返回包含十六进制代码的字符串。 size是内存块的大小,其位置存储在val中。

std::string byteToHexString(const unsigned char* val, unsigned long long size)
{
    unsigned char temp;
    std::string vf;
    vf.resize(2 * size+1);
    for(unsigned long long i= 0; i < size; i++)
    {
        temp = val[i] / 16;
        vf[2*i] = (temp <= 9)? '0' + temp: 'A' + temp - 10; // i.e., (10 = 9  + 1)
        temp = val[i] % 16;

        vf[2*i+1] = (temp <= 9)? '0' + temp: 'A' + temp - 10; // i.e., (10 = 9  + 1)
   }

vf[2*size] = '\0';
return (vf);
}

所以按以下方式执行上述功能:

int main()
{
     unsigned int a = 5555;
     std::cout << byteToHexString((unsigned char*)(&a), 4);
    return 0; 
}

我们获得的输出是:

B3150000

输出不应该是000015B3吗?那么为什么这个以相反的顺序显示呢?代码有问题(我在Ubuntu中使用g ++编译器)?

1 个答案:

答案 0 :(得分:3)

您正在查看存储字节的顺序,以表示架构上的整数,这恰好是 little-endian 。这意味着,最不重要的字节首先出现。

如果要以普通数字形式显示它,您需要检测架构的字节顺序并相应地切换代码,或者只使用字符串流:

unsigned int a = 5555;
std::ostringstream ss;
ss << std::setfill( '0' ) << std::setw( sizeof(a)*2 ) << std::hex << a;
std::cout << ss.str() << std::endl;