• <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ù)  更多評論   

            久久久久久国产a免费观看不卡| 久久国产精品一国产精品金尊| 9999国产精品欧美久久久久久| 久久―日本道色综合久久| 久久婷婷五月综合成人D啪| 久久强奷乱码老熟女网站| 久久综合丝袜日本网| 欧美精品九九99久久在观看| 久久久91精品国产一区二区三区| 久久这里只有精品视频99| 麻豆成人久久精品二区三区免费| 99久久人人爽亚洲精品美女| 99久久精品国产一区二区| 久久精品国产99国产电影网| 99久久精品国产一区二区| 无码任你躁久久久久久久| 国产精品久久影院| 97精品国产97久久久久久免费| 久久久精品无码专区不卡| 久久婷婷久久一区二区三区| 久久人爽人人爽人人片AV| 国产精品久久久久久五月尺| 伊人丁香狠狠色综合久久| AAA级久久久精品无码片| 欧美黑人激情性久久| 久久亚洲精品无码aⅴ大香| 欧美激情精品久久久久久久九九九 | 亚洲&#228;v永久无码精品天堂久久 | 亚洲天堂久久精品| 777米奇久久最新地址| 狼狼综合久久久久综合网| 久久国产欧美日韩精品| 久久亚洲sm情趣捆绑调教| 久久99这里只有精品国产| 亚洲七七久久精品中文国产| 欧美午夜A∨大片久久 | 国产精品久久自在自线观看| 1000部精品久久久久久久久| 99久久久国产精品免费无卡顿| 色妞色综合久久夜夜| 国产精品久久久久久搜索|