说明:

记事本txt有四种编码方式,分别为:UTF-8、ANSI、Unicode和Unicode big endian,当进行写操作,创建的txt编码格式,与写入汉字的编码方式相同;如果写入的汉字是不同的编码方式,此时创建的txt中,会出现乱码,所以需要把汉字转化为同一编码方式。

本文主要介绍:把汉字编码方式,由ANSI方式转化为UTF-8方式:

一、ANSI转化为UTF-8程序:

  1. CString ToUTF8(const wchar_t* buffer, int len)  //返回类型为CString
  2. {
  3. int size = ::WideCharToMultiByte(CP_UTF8, 0, buffer, len, NULL, 0, NULL,
  4. NULL);
  5. if (size == 0)
  6. return "";
  7. std::string newbuffer;
  8. newbuffer.resize(size);
  9. ::WideCharToMultiByte(CP_UTF8, 0, buffer, len,
  10. const_cast<char*>(newbuffer.c_str()), size, NULL, NULL);
  11. //如需返回string类型,直接 return newbuffer
  12. TCHAR outstr[64]; //string 转化为CString返回
  13. CString strTemp;
  14. memset(outstr, '\0', sizeof(outstr));
  15. memcpy(outstr,newbuffer.c_str(),newbuffer.size());
  16. strTemp.Format("%s",outstr);
  17. return strTemp;
  18. }
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&lt;char*&gt;(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;

}

二、函数调用形式

  1. wstring text =  L"汉字";
  2. CString strTemp = ToUTF8(text.c_str(),text.size());
wstring text =  L"汉字";
CString strTemp = ToUTF8(text.c_str(),text.size());

05-28 02:52