stringstream >> uint8_t十六进制?C++

use*_*183 5 c++ hex stream uint8t

我对以下代码的输出感到困惑:

uint8_t x = 0, y = 0x4a;
std::stringstream ss;
std::string a = "4a";


ss << std::hex << a;
ss >> x;

std::cout << (int)x << " "<< (int)y << std::endl;
std::cout << x << " "<< y <<std::endl;
std::cout << std::hex << (int)x <<  " " << (int)y << std::endl;

uint8_t z(x);
std::cout << z;
Run Code Online (Sandbox Code Playgroud)

上面的输出是:

52 74

4 J

34 4a

4

当我们改变时将第一行替换为:

uint16_t x = 0, y = 0x4a;
Run Code Online (Sandbox Code Playgroud)

输出变成:

74 74

74 74

4a 4a

Ĵ

我想我明白会发生什么,但我不明白为什么会发生这种情况或我如何防止/解决它.从我的理解std::hex修饰符以某种方式被破坏,因为它的类型x,在技术层面可能不完全正确,但它只是写它读取的第一个字符.

背景:输入应该是一个十六进制数字的字符串,每对代表一个字节(就像字符串中的位图一样).我希望能够读取每个字节并将其存储在一个uint8_t所以当我遇到这个问题时我正在试验它.我仍然无法确定什么是最好的方法,所以如果你认为我正在做的是低效或不必要的我会很高兴知道为什么.谢谢你的阅读,

Dmi*_*ich 2

ss >> x
Run Code Online (Sandbox Code Playgroud)

将 uint8_t x 视为无符号字符。'4' 的 ascii 值为(十进制)52。它将字符串“4a”的第一个字符读入 x,就好像 x 是一个字符一样。当您将其切换为 uint16_t 时,它会将其视为无符号短整数类型。与 y 相同。