字符转码一直是C++编程中的老大难问题,由于不同编码的规则不同,造成中文字符经常出现乱码,这里记录几个常见的字符编码之间的转换代码(C++)
UTF-8转Unicode
std::wstring Utf82Unicode(const std::string& utf8string)
{
int widesize = ::MultiByteToWideChar(CP_UTF8, 0, utf8string.c_str(), -1, NULL, 0);
if (widesize == ERROR_NO_UNICODE_TRANSLATION)
{
throw std::exception("Invalid UTF-8 sequence.");
}
if (widesize == 0)
{
throw std::exception("Error in conversion.");
}
std::vector<wchar_t> resultstring(widesize);
int convresult = ::MultiByteToWideChar(CP_UTF8, 0, utf8string.c_str(), -1, &resultstring[0], widesize);
if (convresult != widesize)
{
throw std::exception("La falla!");
}
return std::wstring(&resultstring[0]);
}
Unicode 转为 Ascii
string WideByte2Acsi(wstring& wstrcode)
{
int

本文详细介绍了C++中字符编码的转换,包括UTF-8到Unicode,Unicode到ASCII,UTF-8到ASCII,ASCII到Unicode,Unicode到UTF-8以及ASCII到UTF-8的转换代码,旨在解决编程中遇到的字符乱码问题。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



