以下代码(在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 ++编译器)?
答案 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;