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

            隨感而發

            雜七雜八

            統計

            留言簿(13)

            閱讀排行榜

            評論排行榜

            WCHAR我不再懼怕了

            寬字符已經困擾我很久了,以前我都是設置項目的屬性把它改為多字節,不用UNICODE。不過現在又遇到寬字節的問題,沒有辦法,只有硬著頭皮學學:
            我找到的資料:
            http://hi.baidu.com/shongbee2/blog/item/207925546b6cdd5fd10906e0.html
            http://hi.baidu.com/shongbee2/blog/item/d4a057511e9539878c5430cb.html
            看了之后我才發現原來有wcsXXX的函數專門處理寬字節的,就是strXXX一樣好使。呵呵,我不再懼怕了,就試著自己寫了一下,還是學了蠻多東西的:
            1.有wcsXXX的函數和strXXX的函數對應處理寬字節,wcslen就是求長度的,wcscmp就是比較兩個字符串的。
            2.輸出也有相關的操作,wprintf(L”%s%s”);這樣的操作,對文件也可以用fwprintf函數來輸出。不過我發現貌似cout << wchar;不成功。也發現了一個問題,就是我輸出”相等”這樣一個字符串的時候,發現居然輸出不正確,無論是控制臺和文件都有錯誤。可見,這個還是有點小問題的。輸出其他的例如”12345”等都是正常的。哎,這個函數并不可靠啊。
            3.寬字節和普通串的轉換問題,學了兩個函數,一個是:
            wcstombs(char* strDes, const wchar*, size_t nMax);這個函數的作用是把wchar轉換為char。
            char* strDes 為保存轉換后的普通字符串,wchar* 要被轉換的寬字符串。轉換的最大長度。這里的長度是轉換的個數,而不是字節長度。
            mbstowcs() 就是一個相反的過程了,參數就不說了。

            另一套轉換的函數是:
            int WideCharToMultiByte(
              UINT CodePage,
              DWORD dwFlags,
              LPCWSTR lpWideCharStr,
              int cchWideChar,
              LPSTR lpMultiByteStr,
              int cbMultiByte,
              LPCSTR lpDefaultChar,    
              LPBOOL lpUsedDefaultChar
            );
            他的參數很多,上面的連接有介紹,這里就不怎么細說了。
            第一個是編碼的方式,我一般用CP_ACP。第二個是轉換標志,MSDN上說什么都不設置更快,然后我就什么都不管了就用NULL了。具體作用不知道,等遇到了再學。第三個參數就是被轉換的字符串,第四個參數是該字符串的長度,-1表示自動算長度,如果是手動給出,一定要把最后的終結符長度也算上。我覺得還是-1來的實際。第五個參數就是保存轉換串的指針,第六個參數就是保存串的長度,這里是單位字符的個數。如果轉換的時候沒有終結符,那么結果也沒有終結符,要注意下。最后兩個參數就是默認的填充字符和是否使用了默認填充字符,我一般就用NULL代替。

            普通串轉寬字節也是類似。
            這里有幾個注意的,一定要保證空間足夠。還有就是那個長度是單位字符個數,而不是字節數,在轉換時,推薦被轉換的字符串長度設置為-1,因為這樣他會自動算出終結符結束。返回值也是轉換的單位字符個數。例如”相等”有普通串轉換為寬字節串,返回結果是3,(有終結符),而反過來就是5。如果返回時0 說明轉換失敗。

            心得:雖然WideCharToMultiByte的參數要多,感覺用的沒有wcstombs爽,可是他的準確好高一些,要轉換的話,還用用WideCharToMultiByte比較合適,還有就是雖然有一套wcsXXX的庫函數,可惜輸出還是出現問題的。如果全都用寬字節,那沒有關系wcsxxx的函數還是蠻好用的。還有一個疑惑我明明查字典multi是多的意思也就是說multibyte是多字節,我的中文版VS2005配置里面也是說的多字節。搞不懂為什么要用寬字節呢?可能是多字節編碼不好用吧。呵呵。 廢話也說完了,奉上源代碼:
            #include <iostream>
            #include 
            <fstream>
            #include 
            <windows.h>
            using namespace std;

            int main()
            {
                FILE
            * fp ;
                WCHAR wchar[
            5= L"相等相等";        //定義一個寬字節的變量,初始為"相等"
                fp = fopen("1.txt""w+");        //打開文件稱奧做
                fwprintf(fp, L"%s\n", wchar);    //輸出到文件
                fclose(fp);                        //關閉文件
                WCHAR wc2[5];                    //定義第二個寬字節變量
                
                
            //wc開始的有很多寬字節的操作。都和str相對應。
                wcscpy(wc2, wchar);                //復制。
                int n = wcscmp(wc2, wchar);        //比較
                if (n == 0)
                {
                    wprintf(L
            "相等\n");            //這里是否注意到沒有wprintf有問題的。
                }

                
            char str[10];                    //定義char字符。
                n = wcstombs(str, wc2, 9);        //寬字節轉換為muiltychar
                printf("%s\n", str);            //輸出結果

                
            for (int i = 0; i < 5++i)
                {
                    wc2[i] 
            = L'1' + i;
                }
                wc2[
            4= 0;

                n 
            = wcstombs(str, wc2, 9);        //寬字節轉換為muiltychar
                printf("%s\n", str);            //輸出結果
                
            //另外的方式轉換
                n = WideCharToMultiByte(CP_ACP, NULL, wchar, wcslen(wchar) + 1, str, 1000);
                printf(
            "%s\n", str);
                
            char str2[10= "加一";
                WCHAR wc3[
            10];
                n 
            = MultiByteToWideChar(CP_ACP, NULL, str2, strlen(str2) + 1, wc3, 10);    //char到寬字節。

                system(
            "pause");
                
            return 0;
            }
            不要臉的再次放入精華區,因為我覺得他困擾我太久了。呵呵

            posted on 2009-04-28 20:09 shongbee2 閱讀(32338) 評論(15)  編輯 收藏 引用 所屬分類: COM相關

            評論

            # re: WCHAR我不再懼怕了 2009-04-28 21:42 runsisi

            wcout<<L"相等";  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-28 21:45 wcc

            VC2005的標準庫也支持寬字符的,名字前加w就行了,wcout << ...  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-28 21:52 shongbee2

            哦。。我真笨啊。。居然沒有想到。。謝謝你們!
            可惜剛剛試了一下,雖然可以輸出了,但是輸出"相等"字符串的時候還是出現了問題。呵呵,謝謝你們!  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-28 22:34 小游戲

            我很懼怕代碼! 汗!!  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-28 22:40 OwnWaterloo

            @shongbee2

            #include <locale>

            wcout<<L"漢字";
            assert( !wcout );

            wcout.imbue(locale("chs"));
            wcout.clear();
            wcout<<L"漢字";

              回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 07:43 poco

            whar在跨平臺時太多問題  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 07:51 poco

            whchar_t在windows下是兩個字節,在Linux下是4字節,要想wchar_t在linux下也是兩字節,gcc 加-fshort-wchar編譯選項。  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 08:33 guest

            如果是針對windows,那么就用TCHAR,兼容MBCS和UNICODE兩種了。
            strcpy,wcscpy對應_tcscpy。。等等  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 09:04 岳陽

            嗯,用_tcsXXX挺好。  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 12:59 shongbee2

            @OwnWaterloo
            謝謝您,可以了。謝謝。原來要設置一下語言環境啊。  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 13:00 shongbee2

            @guest
            謝謝。。我試試。呵呵。
            沒有想到寬字節這么難用。呵呵。
              回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-29 15:31 tangxinfa

            我現在是統一用char了,需要寬字符時再轉換,呵呵。  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-04-30 20:30 shongbee2

            @tangxinfa
            哈哈,我也一樣。
            不過貌似寬字節是個趨勢。。  回復  更多評論   

            # re: WCHAR我不再懼怕了 2009-05-03 18:05 zhupf

            語言環境要設置的.哈哈.
            這個我也是嘗試過之后才知道 .
            不然輸出顯示是亂碼.  回復  更多評論   

            # re: WCHAR我不再懼怕了 2011-08-30 19:59 yangtzerong


            wcstombs在xp用的不好
            WideCharToMultiByte比較好  回復  更多評論   

            亚洲国产另类久久久精品黑人| 成人综合久久精品色婷婷| 久久经典免费视频| 日韩十八禁一区二区久久| 国产伊人久久| 精品久久久久久无码中文字幕| 久久国产乱子精品免费女| 久久99国产精品99久久| 精品国产福利久久久| 久久精品国产免费| 精品久久久久久久久久久久久久久| 亚洲国产精品婷婷久久| 久久国产视屏| 久久精品无码一区二区WWW| 中文字幕人妻色偷偷久久| 婷婷久久香蕉五月综合加勒比| 久久久久久无码Av成人影院| 久久99精品久久久久久久久久| 久久91综合国产91久久精品| 久久久久18| 久久综合给合久久狠狠狠97色| 国产精品岛国久久久久| 久久精品国产精品亚洲人人| 欧美激情一区二区久久久| 国产亚洲欧美成人久久片| 久久国产免费直播| 日日噜噜夜夜狠狠久久丁香五月| 国产精品久久久久久福利漫画| 久久久久亚洲爆乳少妇无| 伊人久久大香线蕉AV色婷婷色| 色综合久久最新中文字幕| 亚洲天堂久久久| 94久久国产乱子伦精品免费 | 久久e热在这里只有国产中文精品99| 久久人人爽人人爽人人片AV东京热| 国产精品亚洲综合久久 | 久久亚洲国产午夜精品理论片| 精品久久久久久久久久中文字幕| 18岁日韩内射颜射午夜久久成人| 国产成人精品久久一区二区三区av | 麻豆精品久久久一区二区|