U8ToUnicode

CString U8ToUnicode(char* szU8) 
{ 
 //UTF8 to Unicode 
 //由于中文直接复制过来会成乱码,编译器有时会报错,故采用进制形式
 //ar* szU8 = "abcd1234\xe4\xbd\xa0\xe6\x88\x91\xe4\xbb\x96\x00"; 
 //预转换,得到所需空间的大小
 int wcsLen = ::MultiByteToWideChar(CP_UTF8, NULL, szU8, strlen(szU8), NULL, 0); 
 //分配空间要给'\0'留个空间,MultiByteToWideChar不会给'\0'空间
 wchar_t* wszString = new wchar_t[wcsLen + 1]; 
 //转换
 ::MultiByteToWideChar(CP_UTF8, NULL, szU8, strlen(szU8), wszString, wcsLen); 
 //最后加上'\0' 
 wszString[wcsLen] = '\0'; 
 CString strw(wszString);
 delete [] wszString;
 return strw;
 //写文本同ansi to unicode 
}

你可能感兴趣的:(U8ToUnicode)