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

            隨感而發(fā)

            雜七雜八

            統(tǒng)計

            留言簿(13)

            閱讀排行榜

            評論排行榜

            WCHAR我不再懼怕了

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

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

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

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

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

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

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

                n 
            = wcstombs(str, wc2, 9);        //寬字節(jié)轉(zhuǎn)換為muiltychar
                printf("%s\n", str);            //輸出結(jié)果
                
            //另外的方式轉(zhuǎn)換
                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到寬字節(jié)。

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

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

            評論

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

            wcout<<L"相等";  回復(fù)  更多評論   

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

            VC2005的標(biāo)準(zhǔn)庫也支持寬字符的,名字前加w就行了,wcout << ...  回復(fù)  更多評論   

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

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

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

            我很懼怕代碼! 汗!!  回復(fù)  更多評論   

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

            @shongbee2

            #include <locale>

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

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

              回復(fù)  更多評論   

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

            whar在跨平臺時太多問題  回復(fù)  更多評論   

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

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

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

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

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

            嗯,用_tcsXXX挺好。  回復(fù)  更多評論   

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

            @OwnWaterloo
            謝謝您,可以了。謝謝。原來要設(shè)置一下語言環(huán)境啊。  回復(fù)  更多評論   

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

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

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

            我現(xiàn)在是統(tǒng)一用char了,需要寬字符時再轉(zhuǎn)換,呵呵。  回復(fù)  更多評論   

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

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

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

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

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


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

            久久综合丝袜日本网| 久久国产免费直播| 久久久久久毛片免费看| 奇米影视7777久久精品人人爽| 久久亚洲AV成人无码国产| 狠狠人妻久久久久久综合| 久久人人爽人人人人片av| 久久91精品国产91久久小草| 九九久久精品无码专区| 久久99热只有频精品8| 久久综合视频网| 久久综合综合久久97色| 久久99精品久久久久久hb无码| 日韩va亚洲va欧美va久久| 欧美亚洲国产精品久久蜜芽| 日韩人妻无码精品久久免费一| 国产午夜电影久久| 国产精品久久久久久福利漫画| 久久精品国产欧美日韩99热| 国产精品一区二区久久精品无码 | 91亚洲国产成人久久精品| 久久久久亚洲AV片无码下载蜜桃| 一级a性色生活片久久无少妇一级婬片免费放 | 97精品久久天干天天天按摩| 无码久久精品国产亚洲Av影片| 久久综合鬼色88久久精品综合自在自线噜噜| 精品999久久久久久中文字幕| 久久丫精品国产亚洲av| 伊人色综合久久天天人手人婷 | 2022年国产精品久久久久| 色狠狠久久AV五月综合| 久久久久久久亚洲Av无码| 麻豆AV一区二区三区久久| 久久亚洲欧美国产精品| 久久久久99精品成人片欧美| 久久偷看各类wc女厕嘘嘘| 国产精品久久久久久吹潮| 久久久国产精品网站| 久久国产香蕉视频| 亚洲国产综合久久天堂| 亚洲AV无码成人网站久久精品大|