• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            春暖花開
            雪化了,花開了,春天來了
            posts - 149,comments - 125,trackbacks - 0
            //========================================================================
            //TITLE:
            //    MultiByteToWideChar和WideCharToMultiByte用法詳解
            //AUTHOR:
            //    norains
            //DATE:
            //    第一版:Monday  25-December -2006
            //    增補版:Wednesday 27-December -2006
            //    修訂版:Wednesday 14-March-2007 (修正之前的錯誤例子)
            //    再次修訂版:Tuesday 18-September-2007 (修正代碼的參數(shù)錯誤)
            //Environment:
            //  EVC4.0 + Standard SDK
            //========================================================================
             
            1.使用方法詳解

              在本文開始之處,先簡要地說一下何為短字符和寬字符.
              所謂的短字符,就是用8bit來表示的字符,典型的應(yīng)用是ASCII碼.而寬字符,顧名思義,就是用16bit表示的字符,典型的有UNICODE.關(guān)于windows下的ASCII和UNICODE的更多信息,可以參考這兩本經(jīng)典著作:《windows 程序設(shè)計》,《windows 核心編程》.這兩本書關(guān)于這兩種字符都有比較詳細的解說.
             
              寬字符轉(zhuǎn)換為多個短字符是一個難點,不過我們只要掌握到其中的要領(lǐng),便可如魚得水.
              好吧,那就讓我們開始吧.
             
              這個是我們需要轉(zhuǎn)化的多字節(jié)字符串:  
              char sText[20] = {"多字節(jié)字符串!OK!"};
             
              我們需要知道轉(zhuǎn)化后的寬字符需要多少個數(shù)組空間.雖然在這個里程里面,我們可以直接定義一個20*2寬字符的數(shù)組,并且事實上將運行得非常輕松愉快.但假如多字節(jié)字符串更多,達到上千個乃至上萬個,我們將會發(fā)現(xiàn)其中浪費的內(nèi)存將會越來越多.所以以多字節(jié)字符的個數(shù)的兩倍作為寬字符數(shù)組下標(biāo)的聲明絕對不是一個好主意.
              所幸,我們能夠確知所需要的數(shù)組空間.
              我們只需要將MultiByteToWideChar()的第四個形參設(shè)為-1,即可返回所需的短字符數(shù)組空間的個數(shù):
              DWORD dwNum = MultiByteToWideChar (CP_ACP, 0, sText, -1, NULL, 0);
             
              接下來,我們只需要分配響應(yīng)的數(shù)組空間:
              wchar_t *pwText;
              pwText = new wchar_t[dwNum];
              if(!pwText)
              {
               delete []pwText;
              }
             
              接著,我們就可以著手進行轉(zhuǎn)換了.在這里以轉(zhuǎn)換成ASCII碼做為例子:
              MultiByteToWideChar (CP_ACP, 0, sText, -1, pwText, dwNum);
             
              最后,使用完畢當(dāng)然要記得釋放占用的內(nèi)存:
              delete []pwText;
             
             
              同理,寬字符轉(zhuǎn)為多字節(jié)字符的代碼如下:  
              wchar_t wText[20] = {L"寬字符轉(zhuǎn)換實例!OK!"};
              DWORD dwNum = WideCharToMultiByte(CP_OEMCP,NULL,wText,-1,NULL,0,NULL,FALSE);
              char *psText;
              psText = new char[dwNum];
              if(!psText)
              {
               delete []psText;
              }
              WideCharToMultiByte (CP_OEMCP,NULL,wText,-1,psText,dwNum,NULL,FALSE);
              delete []psText;
             
               如果之前我們已經(jīng)分配好空間,并且由于字符串較短,可以不理會浪費的空間,僅僅只是想簡單地將短字符和寬字符相互轉(zhuǎn)換,那有沒有什么簡便的方法呢?
               WIN32 API里沒有符合這種要求的函數(shù),但我們可以自己進行封裝:
                 
              //-------------------------------------------------------------------------------------
              //Description:
              // This function maps a character string to a wide-character (Unicode) string
              //
              //Parameters:
              // lpcszStr: [in] Pointer to the character string to be converted
              // lpwszStr: [out] Pointer to a buffer that receives the translated string.
              // dwSize: [in] Size of the buffer
              //
              //Return Values:
              // TRUE: Succeed
              // FALSE: Failed
              //
              //Example:
              // MByteToWChar(szA,szW,sizeof(szW)/sizeof(szW[0]));
              //---------------------------------------------------------------------------------------
              BOOL MByteToWChar(LPCSTR lpcszStr, LPWSTR lpwszStr, DWORD dwSize)
              {
                // Get the required size of the buffer that receives the Unicode
                // string.
                DWORD dwMinSize;
                dwMinSize = MultiByteToWideChar (CP_ACP, 0, lpcszStr, -1, NULL, 0);
             
                if(dwSize < dwMinSize)
                {
                 return FALSE;
                }
             
                
                // Convert headers from ASCII to Unicode.
                MultiByteToWideChar (CP_ACP, 0, lpcszStr, -1, lpwszStr, dwMinSize);  
                return TRUE;
              }
             
              //-------------------------------------------------------------------------------------
              //Description:
              // This function maps a wide-character string to a new character string
              //
              //Parameters:
              // lpcwszStr: [in] Pointer to the character string to be converted
              // lpszStr: [out] Pointer to a buffer that receives the translated string.
              // dwSize: [in] Size of the buffer
              //
              //Return Values:
              // TRUE: Succeed
              // FALSE: Failed
              //
              //Example:
              // MByteToWChar(szW,szA,sizeof(szA)/sizeof(szA[0]));
              //---------------------------------------------------------------------------------------
              BOOL WCharToMByte(LPCWSTR lpcwszStr, LPSTR lpszStr, DWORD dwSize)
              {
               DWORD dwMinSize;
               dwMinSize = WideCharToMultiByte(CP_OEMCP,NULL,lpcwszStr,-1,NULL,0,NULL,FALSE);
               if(dwSize < dwMinSize)
               {
                return FALSE;
               }
               WideCharToMultiByte(CP_OEMCP,NULL,lpcwszStr,-1,lpszStr,dwSize,NULL,FALSE);
               return TRUE;
              }
             
             
              使用方法也很簡單,示例如下:
              wchar_t wText[10] = {L"函數(shù)示例"};
              char sText[20]= {0};
              WCharToMByte(wText,sText,sizeof(sText)/sizeof(sText[0]));
              MByteToWChar(sText,wText,sizeof(wText)/sizeof(wText[0]));
             
              這兩個函數(shù)的缺點在于無法動態(tài)分配內(nèi)存,在轉(zhuǎn)換很長的字符串時可能會浪費較多內(nèi)存空間;優(yōu)點是,在不考慮浪費空間的情況下轉(zhuǎn)換較短字符串非常方便.

             
            2.MultiByteToWideChar()函數(shù)亂碼的問題

              有的朋友可能已經(jīng)發(fā)現(xiàn),在標(biāo)準(zhǔn)的WinCE4.2或WinCE5.0 SDK模擬器下,這個函數(shù)都無法正常工作,其轉(zhuǎn)換之后的字符全是亂碼.及時更改MultiByteToWideChar()參數(shù)也依然如此.
              不過這個不是代碼問題,其結(jié)癥在于所定制的操作系統(tǒng).如果我們定制的操作系統(tǒng)默認語言不是中文,也會出現(xiàn)這種情況.由于標(biāo)準(zhǔn)的SDK默認語言為英文,所以肯定會出現(xiàn)這個問題.而這個問題的解決,不能在簡單地更改控制面板的"區(qū)域選項"的"默認語言",而是要在系統(tǒng)定制的時候,選擇默認語言為"中文".
              系統(tǒng)定制時選擇默認語言的位置于:
              Platform -> Setting... -> locale -> default language ,選擇"中文",然后編譯即可.

            摘自:
            http://blog.csdn.net/norains/archive/2006/12/25/1461174.aspx
            posted on 2009-02-09 17:10 Sandy 閱讀(458) 評論(0)  編輯 收藏 引用 所屬分類: Window Mobile
            亚洲国产精久久久久久久| 久久99精品久久久久久不卡| 伊人久久综合精品无码AV专区| 久久久久国产精品麻豆AR影院 | 久久ZYZ资源站无码中文动漫| 久久精品蜜芽亚洲国产AV| 色综合久久88色综合天天| 亚洲欧洲中文日韩久久AV乱码| 亚洲精品美女久久777777| 99久久99久久精品国产片| 亚洲熟妇无码另类久久久| 国产成人综合久久精品尤物| 亚洲国产另类久久久精品黑人| 久久www免费人成看国产片| 日产精品久久久一区二区| 久久精品国产欧美日韩| 久久福利青草精品资源站免费| 久久99国产精品久久99小说| 一本色道久久88加勒比—综合| 无码精品久久久天天影视 | 亚洲精品无码久久久久AV麻豆| 精品国产VA久久久久久久冰 | WWW婷婷AV久久久影片| 婷婷久久综合九色综合九七| 69国产成人综合久久精品| 亚洲国产一成久久精品国产成人综合| 久久精品国产亚洲精品2020| 伊人久久综合无码成人网| 久久这里的只有是精品23| 久久久久亚洲av毛片大| 久久精品中文字幕有码| 91精品国产91久久久久久蜜臀| 国产美女久久精品香蕉69| 久久久一本精品99久久精品66| 伊人久久综合精品无码AV专区| 囯产精品久久久久久久久蜜桃| 久久久久久伊人高潮影院| 久久亚洲AV成人无码软件| 亚洲AV无码久久精品成人 | 国产成人精品久久二区二区| 久久精品毛片免费观看|