• <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>

            Welcome to ErranLi's Blog!

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              106 Posts :: 1 Stories :: 97 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(12)

            搜索

            •  

            積分與排名

            • 積分 - 174947
            • 排名 - 151

            最新評論

            閱讀排行榜

            在進行ce的開發時,經常設計到字符的轉換,特別是系統中包含網絡通訊時,更是如此。ce中均是Unicode編碼,而網絡通訊一般都使用BYTE進行數據傳輸。

            以下是在網上找到的一篇文章,介紹的很詳細。

            ?1.使用方法詳解

            ? 在本文開始之處,先簡要地說一下何為短字符和寬字符.
            ? 所謂的短字符,就是用8bit來表示的字符,典型的應用是ASCII碼.而寬字符,顧名思義,就是用16bit表示的字符,典型的有UNICODE.關于windows下的ASCII和UNICODE的更多信息,可以參考這兩本經典著作:《windows 程序設計》,《windows 核心編程》.這兩本書關于這兩種字符都有比較詳細的解說.
            ?
            ? 寬字符轉換為多個短字符是一個難點,不過我們只要掌握到其中的要領,便可如魚得水.
            ? 好吧,那就讓我們開始吧.
            ?
            ? 這個是我們需要轉化的多字節字符串: ?
            ? char sText[20] = {"多字節字符串!OK!"};
            ?
            ? 我們需要知道轉化后的寬字符需要多少個數組空間.雖然在這個里程里面,我們可以直接定義一個20*2寬字符的數組,并且事實上將運行得非常輕松愉快.但假如多字節字符串更多,達到上千個乃至上萬個,我們將會發現其中浪費的內存將會越來越多.所以以多字節字符的個數的兩倍作為寬字符數組下標的聲明絕對不是一個好主意.
            ? 所幸,我們能夠確知所需要的數組空間.
            ? 我們只需要將MultiByteToWideChar()的第四個形參設為-1,即可返回所需的短字符數組空間的個數:
            ? DWORD dwNum = MultiByteToWideChar (CP_ACP, 0, sText, -1, NULL, 0);
            ?
            ? 接下來,我們只需要分配響應的數組空間:
            ? wchar_t *pwText;
            ? pwText = new wchar_t[dwNum];
            ? if(!pwText)
            ? {
            ?? delete []pwText;
            ? }
            ?
            ? 接著,我們就可以著手進行轉換了.在這里以轉換成ASCII碼做為例子:
            ? MultiByteToWideChar (CP_ACP, 0, psText, -1, sText, dwSize);
            ?
            ? 最后,使用完畢當然要記得釋放占用的內存:
            ? delete []psText;
            ?
            ?
            ? 同理,寬字符轉為多字節字符的代碼如下: ?
            ? wchar_t wText[20] = {L"寬字符轉換實例!OK!"};
            ? DWORD dwNum = WideCharToMultiByte(CP_OEMCP,NULL,lpcwszStr,-1,NULL,0,NULL,FALSE);
            ? char *psText;
            ? psText = new char[dwNum];
            ? if(!psText)
            ? {
            ?? delete []psText;
            ? }
            ? WideCharToMultiByte (CP_OEMCP,NULL,lpcwszStr,-1,psText,dwNum,NULL,FALSE);
            ? delete []psText;
            ?
            ?? 如果之前我們已經分配好空間,并且由于字符串較短,可以不理會浪費的空間,僅僅只是想簡單地將短字符和寬字符相互轉換,那有沒有什么簡便的方法呢?
            ?? WIN32 API里沒有符合這種要求的函數,但我們可以自己進行封裝:
            ??? ?
            ? //-------------------------------------------------------------------------------------
            ? //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"函數示例"};
            ? char sText[20]= {0};
            ? WCharToMByte(wText,sText,sizeof(sText)/sizeof(sText[0]));
            ? MByteToWChar(sText,wText,sizeof(wText)/sizeof(wText[0]));
            ?
            ? 這兩個函數的缺點在于無法動態分配內存,在轉換很長的字符串時可能會浪費較多內存空間;優點是,在不考慮浪費空間的情況下轉換較短字符串非常方便.

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

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

            posted on 2007-10-13 17:55 erran 閱讀(3198) 評論(0)  編輯 收藏 引用 所屬分類: WinCE
            久久精品成人免费观看97| 久久国产精品成人影院| 久久免费国产精品| 99久久这里只精品国产免费| 亚洲综合伊人久久综合| 好属妞这里只有精品久久| 欧美大战日韩91综合一区婷婷久久青草 | 欧美日韩精品久久免费| 久久久久亚洲AV无码专区首JN| 久久久久国产精品熟女影院| 亚洲国产天堂久久综合网站| 久久这里有精品| 久久综合狠狠色综合伊人| 人人狠狠综合久久亚洲高清| 久久精品人人做人人妻人人玩| 久久久久噜噜噜亚洲熟女综合| 久久久久亚洲av无码专区| 久久精品国产亚洲一区二区三区| 久久久久国产精品熟女影院 | 久久WWW免费人成一看片| 久久综合狠狠色综合伊人| 无码任你躁久久久久久老妇App| 国产99久久久国产精免费| 乱亲女H秽乱长久久久| 亚洲精品国精品久久99热| 中文字幕久久欲求不满| 久久av无码专区亚洲av桃花岛| 久久笫一福利免费导航| 99久久99久久精品国产片果冻 | 久久婷婷五月综合成人D啪| 久久不见久久见免费影院www日本| 2021久久国自产拍精品| 久久久久亚洲AV无码网站| 精品久久亚洲中文无码| 久久精品免费一区二区| 精品国产日韩久久亚洲| 模特私拍国产精品久久| 亚洲午夜福利精品久久| 久久久噜噜噜久久中文字幕色伊伊| 色天使久久综合网天天| A级毛片无码久久精品免费|