Windows API一日一練(80)MultiByteToWideChar函數

來源:互聯網
上載者:User
 Windows API一日一練(80)MultiByteToWideChar函數    
在軟體的使用過程中,經常碰到亂碼的情況,那麼亂碼的原因是什麼呢?其實很多情況下,就是字元集的不同,也就是說同一個數字代表不同意思。在Windows裡,目前主要有ANSI和UNICODE的方式。如果在UNICODE的方式裡直接顯示ANSI的字串是出現亂碼的,同樣在ANSI函數裡也不能顯示UNICODE的字串,而是要進行相互轉換才能顯示正確的字串。在NT以後的作業系統裡,Windows底層函數已經全部改為UNICODE的方式,如果還是使用ANSI的話,要比UNICODE函數慢一些,系統底層會從ANSI的方式轉換為UNICODE方式,然後再顯示出來。從ANSI轉換為UNICODE的字串,就可以使用函數MultiByteToWideChar來實現。
 
函數MultiByteToWideChar聲明如下:
 
WINBASEAPI
int
WINAPI
MultiByteToWideChar(
    __in UINT     CodePage,
    __in DWORD    dwFlags,
    __in LPCSTR   lpMultiByteStr,
    __in int      cbMultiByte,
    __out_ecount_opt(cchWideChar) LPWSTR lpWideCharStr,
    __in int      cchWideChar);
CodePage是代碼錶。
dwFlags是轉換標誌。
lpMultiByteStr是輸入ANSI字串。
cbMultiByte是輸入ANSI的字串長度。
lpWideCharStr是輸出UNICODE字串。
cchWideChar是輸出UNICODE字串的緩衝區大小。
 
調用函數的例子如下:
#001 //
#002  //字串轉換。
#003  //蔡軍生 2007/11/28 QQ:9073204 深圳
#004  void MultiToWide(void)
#005  {
#006         //ANSI的字串。
#007         std::string strANSI("測試字串轉換/r/n");
#008
#009         //
#010         const int nBufSize = 512;
#011         TCHAR chBuf[nBufSize];
#012         ZeroMemory(chBuf,nBufSize);
#013
#014         //轉換為UNICODE的字串。
#015        if (MultiByteToWideChar(CP_ACP,0,strANSI.c_str(),strANSI.length(),
#016              chBuf,nBufSize) > 0)
#017         {
#018               //
#019               OutputDebugString(chBuf);
#020         }
#021
#022  }
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.