UTF8与GBK字符编码之间的相互转换
2012-12-02 19:09
561 查看
1、将UTF8转换成GBK
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));
delete []szGBK;
delete []wszGBK;
}
2、将GBK转换成UTF8
void GBKToUTF8(char* &szOut)
{
char* strGBK = szOut;
int len=MultiByteToWideChar(CP_ACP, 0, (LPCSTR)strGBK, -1, NULL,0);
unsigned short * wszUtf8 = new unsigned short[len+1];
memset(wszUtf8, 0, len * 2 + 2);
MultiByteToWideChar(CP_ACP, 0, (LPCSTR)strGBK, -1, (LPWSTR)wszUtf8, len);
len = WideCharToMultiByte(CP_UTF8, 0, (LPWSTR)wszUtf8, -1, NULL, 0, NULL, NULL);
char *szUtf8=new char[len + 1];
memset(szUtf8, 0, len + 1);
WideCharToMultiByte (CP_UTF8, 0, (LPWSTR)wszUtf8, -1, szUtf8, len, NULL,NULL);
//szOut = szUtf8;
memset(szOut,'/0',strlen(szUtf8)+1);
memcpy(szOut,szUtf8,strlen(szUtf8));
delete[] szUtf8;
delete[] wszUtf8;
}
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));
delete []szGBK;
delete []wszGBK;
}
2、将GBK转换成UTF8
void GBKToUTF8(char* &szOut)
{
char* strGBK = szOut;
int len=MultiByteToWideChar(CP_ACP, 0, (LPCSTR)strGBK, -1, NULL,0);
unsigned short * wszUtf8 = new unsigned short[len+1];
memset(wszUtf8, 0, len * 2 + 2);
MultiByteToWideChar(CP_ACP, 0, (LPCSTR)strGBK, -1, (LPWSTR)wszUtf8, len);
len = WideCharToMultiByte(CP_UTF8, 0, (LPWSTR)wszUtf8, -1, NULL, 0, NULL, NULL);
char *szUtf8=new char[len + 1];
memset(szUtf8, 0, len + 1);
WideCharToMultiByte (CP_UTF8, 0, (LPWSTR)wszUtf8, -1, szUtf8, len, NULL,NULL);
//szOut = szUtf8;
memset(szOut,'/0',strlen(szUtf8)+1);
memcpy(szOut,szUtf8,strlen(szUtf8));
delete[] szUtf8;
delete[] wszUtf8;
}
相关文章推荐
- 字符编码之间的相互转换 UTF8与GBK
- UTF8与GBK字符编码之间的相互转换
- 【miscellaneous】【C/C++语言】UTF8与GBK字符编码之间的相互转换
- 字符编码之间的相互转换 UTF8与GBK(转载)
- UTF8与GBK字符编码之间的相互转换
- Java实现的utf8,gbk,unicode编码相互转换的代码
- iOS 中文与UTF8编码之间的相互转换
- 简要介绍一下UTF-8编码和GBK编码------并利用linux中的iconv命令来实现UTF-8和GBK之间的相互转换
- Java实现的utf8,gbk,unicode编码相互转换的代码
- pb字符串实现GB2312与Unicode、UTF8之间的相互转换
- GBK和UTF8之间的转换 开源
- utf-8和gbk之间相互转换
- UTF8,UTF16,UTF32,UTF16-LE,UTF16-BE,GBK 之间的转换
- GBK和UTF8之间的转换 C语言
- Java实现的utf8,gbk,unicode编码相互转换的代码
- Android NDK的C/C++代码中利用JNI回调实现字符编码转换的试验(中文UTF8与GBK)
- 基于Poco的UTF8、UTF16、GBK、Hex之间的转换
- 跨平台实现GBK和UTF8之间的转换(通过汉字集合实现)
- iOS 中文与UTF8编码之间的相互转换
- qt 下 utf8编码与gbk编码的相互转换(附实例)