说明:
记事本txt有四种编码方式,分别为:UTF-8、ANSI、Unicode和Unicode big endian,当进行写操作,创建的txt编码格式,与写入汉字的编码方式相同;如果写入的汉字是不同的编码方式,此时创建的txt中,会出现乱码,所以需要把汉字转化为同一编码方式。
本文主要介绍:把汉字编码方式,由ANSI方式转化为UTF-8方式:
一、ANSI转化为UTF-8程序:
CString ToUTF8(const wchar_t* buffer, int len) //返回类型为CString
{
int size = ::WideCharToMultiByte(CP_UTF8, 0, buffer, len, NULL, 0, NULL,
NULL);
if (size == 0)
return "";
std::string newbuffer;
newbuffer.resize(size);
::WideCharToMultiByte(CP_UTF8, 0, buffer, len,
const_cast<char*>(newbuffer.c_str()), size, NULL, NULL);
//如需返回string类型,直接 return newbuffer
TCHAR outstr[64]; //string 转化为CString返回
CString strTemp;
memset(outstr, '\0', sizeof(outstr));
memcpy(outstr,newbuffer.c_str(),newbuffer.size());
strTemp.Format("%s",outstr);
return strTemp;
}
二、函数调用形式
wstring text = L"汉字";
CString strTemp = ToUTF8(text.c_str(),text.size());
来源:CSDN
作者:缄默hong
链接:https://blog.csdn.net/hong__fang/article/details/42241825