天天看點

MFC--WideCharToMultiByte和MultiByteToWideChar函數的用法

   為了支援Unicode編碼,需要多位元組與寬位元組之間的互相轉換。這兩個系統函數在使用時需要指定代碼頁,在實際應用過程中遇到亂碼問題,然後重新閱讀《Windows核心程式設計》,總結出正确的用法。

WideCharToMultiByte的代碼頁用來标記與新轉換的字元串相關的代碼頁。

MultiByteToWideChar的代碼頁用來标記與一個多位元組字元串相關的代碼頁。

常用的代碼頁由CP_ACP和CP_UTF8兩個。

使用CP_ACP代碼頁就實作了ANSI與Unicode之間的轉換。

使用CP_UTF8代碼頁就實作了UTF-8與Unicode之間的轉換。

下面是代碼實作:

1.  ANSI to Unicode

wstring ANSIToUnicode( const string& str )

{

 int  len = 0;

 len = str.length();

 int  unicodeLen = ::MultiByteToWideChar( CP_ACP,

            0,

            str.c_str(),

            -1,

            NULL,

            0 ); 

 wchar_t *  pUnicode; 

 pUnicode = new  wchar_t[unicodeLen+1]; 

 memset(pUnicode,0,(unicodeLen+1)*sizeof(wchar_t)); 

 ::MultiByteToWideChar( CP_ACP,

         0,

         str.c_str(),

         -1,

         (LPWSTR)pUnicode,

         unicodeLen ); 

 wstring  rt; 

 rt = ( wchar_t* )pUnicode;

 delete  pUnicode;

 return  rt; 

}

2.  Unicode to ANSI

string UnicodeToANSI( const wstring& str )

{

 char*     pElementText;

 int    iTextLen;

 // wide char to multi char

 iTextLen = WideCharToMultiByte( CP_ACP,

         0,

         str.c_str(),

         -1,

         NULL,

         0,

NULL,

         NULL );

 pElementText = new char[iTextLen + 1];

 memset( ( void* )pElementText, 0, sizeof( char ) * ( iTextLen + 1 ) );

 ::WideCharToMultiByte( CP_ACP,

         0,

         str.c_str(),

         -1,

         pElementText,

         iTextLen,

         NULL,

         NULL );

 string strText;

 strText = pElementText;

 delete[] pElementText;

 return strText;

}

3.  UTF-8 to Unicode

wstring UTF8ToUnicode( const string& str )

{

 int  len = 0;

 len = str.length();

 int  unicodeLen = ::MultiByteToWideChar( CP_UTF8,

            0,

            str.c_str(),

            -1,

            NULL,

            0 ); 

 wchar_t *  pUnicode; 

 pUnicode = new  wchar_t[unicodeLen+1]; 

 memset(pUnicode,0,(unicodeLen+1)*sizeof(wchar_t)); 

 ::MultiByteToWideChar( CP_UTF8,

         0,

         str.c_str(),

         -1,

         (LPWSTR)pUnicode,

         unicodeLen ); 

 wstring  rt; 

 rt = ( wchar_t* )pUnicode;

 delete  pUnicode;

 return  rt; 

}

4.  Unicode to UTF-8   

string UnicodeToUTF8( const wstring& str )

{

 char*     pElementText;

 int    iTextLen;

 // wide char to multi char

 iTextLen = WideCharToMultiByte( CP_UTF8,

         0,

         str.c_str(),

         -1,

         NULL,

         0,

         NULL,

         NULL );

 pElementText = new char[iTextLen + 1];

 memset( ( void* )pElementText, 0, sizeof( char ) * ( iTextLen + 1 ) );

 ::WideCharToMultiByte( CP_UTF8,

         0,

         str.c_str(),

         -1,

         pElementText,

         iTextLen,

         NULL,

         NULL );

 string strText;

 strText = pElementText;

 delete[] pElementText;

 return strText;

}

MFC