实际就是由宽字节转换为多字节的过程ide
-------------post
首先MultiByteToWideChar(CP_UTF8, 0, (LPCSTR)szOut, -1, (LPWSTR)wszGBK, len) 转换UTF-8 到表中UNICODE操作系统
而后编译器
WideCharToMultiByte(CP_ACP, 0, (LPWSTR)wszGBK, -1, szGBK, len, NULL, NULL); UNICODE转换为标准多字节
编译
这个时候已是ANSI格式了,事实上不是GBK格式,但是通常这个时候编译器和操做系统字符集就能去解决下边的事了。就是说可以直接当普通的char *来用了class
---------------
void UTF8ToGBK( char *&szOut )
{
unsigned short *wszGBK;
char *szGBK;
//长度
int len = MultiByteToWideChar(CP_UTF8, 0, (LPCSTR)szOut, -1, NULL, 0);
wszGBK = new unsigned short[len+1];
memset(wszGBK, 0, len * 2 + 2);
MultiByteToWideChar(CP_UTF8, 0, (LPCSTR)szOut, -1, (LPWSTR)wszGBK, len);
//长度
len = WideCharToMultiByte(CP_ACP, 0, (LPWSTR)wszGBK, -1, NULL, 0, NULL, NULL);
szGBK = new char[len+1];
memset(szGBK, 0, len + 1);
WideCharToMultiByte(CP_ACP, 0, (LPWSTR)wszGBK, -1, szGBK, len, NULL, NULL);
//szOut = szGBK; //这样获得的szOut不对,因为此句意义是将szGBK的首地址赋给szOut。当delete []szGBK运行后szGBK的内
//存空间将被释放。此时将得不到szOut的内容
memset(szOut,'0',strlen(szGBK)+1); //改将szGBK的内容赋给szOut ,这样即便szGBK被释放也能获得正确的值
memcpy(szOut,szGBK,strlen(szGBK)+1);//最后这个+1不要忘了
delete []szGBK;
delete []wszGBK;
}
di