我要做的是将字符串的字节转换为十六进制格式。
基于这个答案(以及许多其他一致的答案),我尝试了代码:
#include <sstream>
#include <iomanip>
#include <iostream>
int main ()
{
std::string inputText = u8"A7°";
std::stringstream ss;
// print every char of the string as hex on 2 values
for (unsigned int i = 0; i < inputText.size (); ++i)
{
ss << std::hex << std::setfill ('0') << std::setw (2) << (int) inputText[i];
}
std::cout << ss.str() << std::endl;
}
但是对于某些以 UTF 8 编码的字符,它不起作用。
例如,在包含以 UTF8 编码的度数符号 ( ° ) 的字符串中,结果是:ffffffc2ffffffb0
而不是 c2b0
。
现在我希望算法能够处理单个字节,无论其内容如何,而且结果似乎忽略了setw(2)
参数。
为什么我会得到这样的结果?
(在此处运行测试程序)
正如 Pete Becker 在评论中已经暗示的那样,将负值转换为较大的整数会用"1"填充较高的位。解决方案是先将char
强制转换为unsigned char
,然后再将其转换为int
:
#include <string>
#include <iostream>
#include <iomanip>
int main()
{
std::string inputText = "-12°C";
// print every char of the string as hex on 2 values
for (unsigned int i = 0; i < inputText.size(); ++i)
{
std::cout << std::hex << std::setfill('0')
<< std::setw(2) << (int)(unsigned char)inputText[i];
}
}
setw
设置最小宽度,则不会截断较长的值。