ric*_*ing 4 c++ string hex utf-8
我正在尝试将字符串的字节转换为十六进制格式。
基于此答案(以及许多其他一致的答案),我尝试了代码:
#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;
}
Run Code Online (Sandbox Code Playgroud)
但是某些字符以UTF 8编码则无法正常工作。
对于Instance,在包含以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];
}
}
Run Code Online (Sandbox Code Playgroud)
setw设置最小宽度,它不会截断更长的值。
| 归档时间: |
|
| 查看次数: |
1039 次 |
| 最近记录: |