GB2312和BIG5,Unicode/UTF8等编码之间的互相转化

在工作中经常会用到GB2312和BIG5,Unicode/UTF8等编码之间的互相转化,也有很多程序员对这个问题不断的提问,现在我把我的

实现告诉大家.

#include "Utf8.h"

void ConvertGBKToUtf8(char *strGBK , int maxlen )
{
    int len=MultiByteToWideChar(CP_ACP, 0, (LPCTSTR)strGBK, -1, NULL,0);
    unsigned short * wszUtf8 = new unsigned short[len+1];
    memset(wszUtf8, 0, len * 2 + 2);
    MultiByteToWideChar(CP_ACP, 0, (LPCTSTR)strGBK, -1, wszUtf8, len);
 
    len = WideCharToMultiByte(CP_UTF8, 0, wszUtf8, -1, NULL, 0, NULL, NULL);
    char *szUtf8=new char[len + 1];
    memset(szUtf8, 0, len + 1);
    WideCharToMultiByte (CP_UTF8, 0, wszUtf8, -1, szUtf8, len, NULL,NULL);
 
 
 if (strlen( szUtf8) >= (unsigned)maxlen)
 {
  strncpy( strGBK , szUtf8 , maxlen -1 );
  strGBK[ maxlen -2 ] = 0 ;
  strGBK[ maxlen -1 ] = 0 ;
  
 }
 strcpy( strGBK , szUtf8 );
 
 //  if (wcslen( szUtf8 ) > maxlen )
 //  {
 //   
 //  }
 //     wcscpy(strGBK, szUtf8);
 
    delete[] szUtf8;
    delete[] wszUtf8;
}

void ConvertUtf8ToGBK(char *strUtf8  , int maxlen  )
{
    int len=MultiByteToWideChar(CP_UTF8, 0, (LPCTSTR)strUtf8, -1, NULL,0);
    unsigned short * wszGBK = new unsigned short[len+1];
    memset(wszGBK, 0, len * 2 + 2);
    MultiByteToWideChar(CP_UTF8, 0, (LPCTSTR)strUtf8, -1, wszGBK, len);
 
    len = WideCharToMultiByte(CP_ACP, 0, wszGBK, -1, NULL, 0, NULL, NULL);
    char *szGBK=new char[len + 1];
    memset(szGBK, 0, len + 1);
    WideCharToMultiByte (CP_ACP, 0, wszGBK, -1, szGBK, len, NULL,NULL);
 
 if ( strlen( szGBK ) >= (unsigned)maxlen )
 {
  strncpy( strUtf8 , szGBK , maxlen - 1   ) ;
  strUtf8[maxlen - 1 ] = 0 ;
 }
 else
 {
  strcpy(strUtf8, szGBK);
 }
    delete[] szGBK;
    delete[] wszGBK;
}


wchar_t* GB2312ToUnicode(const char* szGBString)
{
 UINT nCodePage = 936; //GB2312
 int nLength=MultiByteToWideChar(nCodePage,0,szGBString,-1,NULL,0);
 wchar_t* pBuffer = new wchar_t[nLength+1];
 MultiByteToWideChar(nCodePage,0,szGBString,-1,pBuffer,nLength);
 pBuffer[nLength]=0;
 return pBuffer;
}


wchar_t* BIG5ToUnicode(const char* szBIG5String)
{
 UINT nCodePage = 950; //BIG5
 int nLength=MultiByteToWideChar(nCodePage,0,szBIG5String,-1,NULL,0);
 wchar_t* pBuffer = new wchar_t[nLength+1];
 MultiByteToWideChar(nCodePage,0,szBIG5String,-1,pBuffer,nLength);
 pBuffer[nLength]=0;
 return pBuffer;
}
char* UnicodeToGB2312(const wchar_t* szUnicodeString)
{
 UINT nCodePage = 936; //GB2312
 int nLength=WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,NULL,0,NULL,NULL);
 char* pBuffer=new char[nLength+1];
 WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,pBuffer,nLength,NULL,NULL);
 pBuffer[nLength]=0;
 return pBuffer;
}
char* UnicodeToBIG5(const wchar_t* szUnicodeString)
{
 UINT nCodePage = 950; //BIG5
 int nLength=WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,NULL,0,NULL,NULL);
 char* pBuffer=new char[nLength+1];
 WideCharToMultiByte(nCodePage,0,szUnicodeString,-1,pBuffer,nLength,NULL,NULL);
 pBuffer[nLength]=0;
 return pBuffer;
}
char* BIG5ToGB2312(const char* szBIG5String)
{
 LCID lcid = MAKELCID(MAKELANGID(LANG_CHINESE,SUBLANG_CHINESE_SIMPLIFIED),SORT_CHINESE_PRC);
 
 wchar_t* szUnicodeBuff = BIG5ToUnicode(szBIG5String);
 char* szGB2312Buff = UnicodeToGB2312(szUnicodeBuff);
 
 int nLength = LCMapString(lcid,LCMAP_SIMPLIFIED_CHINESE, szGB2312Buff,-1,NULL,0);
 char* pBuffer = new char[nLength + 1];
 LCMapString(0x0804,LCMAP_SIMPLIFIED_CHINESE,szGB2312Buff,-1,pBuffer,nLength);
 pBuffer[nLength] = 0;
 
 delete[] szUnicodeBuff;
 delete[] szGB2312Buff;
 return pBuffer;
}
char* GB2312ToBIG5(const char* szGBString)
{
 LCID lcid = MAKELCID(MAKELANGID(LANG_CHINESE,SUBLANG_CHINESE_SIMPLIFIED),SORT_CHINESE_PRC);
 
 int nLength = LCMapString(lcid,LCMAP_TRADITIONAL_CHINESE,szGBString,-1,NULL,0);
 char* pBuffer=new char[nLength+1];
 LCMapString(lcid,LCMAP_TRADITIONAL_CHINESE,szGBString,-1,pBuffer,nLength);
 pBuffer[nLength]=0;
 
 wchar_t* pUnicodeBuff = GB2312ToUnicode(pBuffer);
 char* pBIG5Buff = UnicodeToBIG5(pUnicodeBuff);
 
 delete[] pBuffer;
 delete[] pUnicodeBuff;
 return pBIG5Buff;
}

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值