我对以下代码的输出感到困惑:
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;
以上的输出是:
52 74
4 J
34 4a
4
当我们更改时将第一行替换为:
uint16_t x = 0, y = 0x4a;
输出变为:
74 74
74 74
4a 4a
Ĵ
我想我明白会发生什么,但我不明白为什么会发生这种情况或我如何阻止它/解决它。从我的理解std::hex
修饰符因为x
的类型而在某种程度上被破坏,在技术层面可能不完全正确,但它只是写出它读取的第一个字符。
背景:输入应该是一个十六进制数字的字符串,每对代表一个字节(就像字符串中的位图一样)。我希望能够读取每个字节并将其存储在uint8_t
中,所以当我遇到这个问题时,我正在试验它。我仍然无法确定什么是最好的方法,所以如果你认为我正在做的是低效或不必要的我会很高兴知道为什么。谢谢你的阅读,
答案 0 :(得分:2)
using (OleDbConnection conn = new OleDbConnection("yourconnectionString"))
{
conn.Open();
using (OleDbCommand cmd =new OleDbCommand("your query text", conn))
{
// execute your command
}
}
将uint8_t x视为unsigned char。 '4'的ascii值是(十进制)52。它将字符串“4a”的第一个字符读取到x中,好像x是一个字符。当你将它切换到uint16_t时,它将它视为无符号短整数类型。与y相同。