LPSTR Convert(LPCSTR str, int sourceCodepage, int targetCodepage)
{
int len=_tcslen(str);
int unicodeLen=MultiByteToWideChar(sourceCodepage,0,str,-1,NULL,0);
wchar_t* pUnicode;
pUnicode=new wchar_t[unicodeLen+1];
memset(pUnicode,0,(unicodeLen+1)*sizeof(wchar_t));
MultiByteToWideChar(sourceCodepage,0,str,-1,(LPWSTR)pUnicode,unicodeLen);
BYTE * pTargetData;
int targetLen=WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,0,NULL,NULL);
pTargetData=new BYTE[targetLen+1];
memset(pTargetData,0,targetLen+1);
WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,targetLen,NULL,NULL);
LPSTR szResult=new TCHAR[targetLen+1];
wsprintf(szResult,"%s",pTargetData);
delete[] pUnicode;
delete[] pTargetData;
return szResult;
}
用法
编码
Convert(str,936,CP_UTF8);
解码
Convert(str,CP_UTF8,936);
字符串UTF-8与ASCII相互转换
最新推荐文章于 2025-10-11 15:59:15 发布
博客给出了一个字符编码转换函数 Convert,该函数接收源字符串、源编码页和目标编码页作为参数,通过 MultiByteToWideChar 和 WideCharToMultiByte 函数实现编码转换,最后释放内存。还给出了编码和解码的具体调用示例。
1570

被折叠的 条评论
为什么被折叠?



