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

            專職C++

            不能停止的腳步

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              163 Posts :: 7 Stories :: 135 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(28)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            這函數(shù),使用的是標(biāo)準(zhǔn)C函數(shù)。需要頭文件cstdlib和clocale。針對(duì)中文的unicode寫(xiě)的函數(shù)。
                    ///將中文Unicode轉(zhuǎn)換為Ansi多字節(jié)字符串
                    /**
                        @param [out] paramDest 保存轉(zhuǎn)換后的字符串
                        @param [in] paramSource 原始的Unicode字符串
                        @param [in] paramDestBytes 用于保存轉(zhuǎn)換后字符串的內(nèi)存字節(jié)數(shù)
                        @return XInt 返回被轉(zhuǎn)換后的字符個(gè)數(shù)(不含結(jié)尾0)
                     
            */
                    inline XInt ChineseUnicodeToMultByte(XChar 
            * paramDest, const XWideChar * paramSource, XInt paramDestBytes)
                    {
                        XChar pCurLocale[
            50];
                        StringCopy(pCurLocale,setlocale(LC_ALL,NULL),
            49);
                        setlocale(LC_ALL,
            "chs");
                        size_t iByteCount 
            = wcstombs(paramDest, paramSource, paramDestBytes);
                        setlocale(LC_ALL, pCurLocale);
                        
            return (XInt)iByteCount;
                    }
                    
            ///將中文Ansi多字節(jié)轉(zhuǎn)換為Unicode字符串
                    /**
                        @param [out] paramDest 保存轉(zhuǎn)換后的字符串
                        @param [in] paramSource 原始的Unicode字符串
                        @param [in] paramDestBytes 用于保存轉(zhuǎn)換后字符串的內(nèi)存字節(jié)數(shù)
                        @return XInt 返回被轉(zhuǎn)換后的字符個(gè)數(shù)(不含結(jié)尾0)
                     
            */
                    inline XInt ChineseMultByteToUnicode(XWideChar 
            * paramDest, const XChar * paramSource,XInt paramDestByte)
                    {
                        setlocale(LC_ALL, 
            "chs"); 
                        size_t iByteCount 
            = mbstowcs(paramDest, paramSource, paramDestByte);
                        setlocale(LC_ALL,
            "C");
                        
            return (XInt)iByteCount;
                    }
            這兩個(gè)函數(shù),已經(jīng)融合到我的那個(gè)字符串XWideString和XAnsiString中,它這兩個(gè)字符串相互轉(zhuǎn)換非常容易。具體語(yǔ)言的參考,可以查看MSDN。
            這兩個(gè)函數(shù)算是對(duì)wcstombs和mbstowcs的一個(gè)使用例子吧。

            posted on 2010-11-01 14:07 冬瓜 閱讀(4022) 評(píng)論(6)  編輯 收藏 引用 所屬分類: 原創(chuàng)

            Feedback

            # re: 一則C++Unicode集與多字節(jié)轉(zhuǎn)換函數(shù)使用。 2010-11-02 10:20 陳梓瀚(vczh)
            嘛,其實(shí)還有API的WideCharToMultiBytes, MultiBytesToWideChar,功能更強(qiáng)大,使用更方便……  回復(fù)  更多評(píng)論
              

            # re: 一則C++Unicode集與多字節(jié)轉(zhuǎn)換函數(shù)使用。 2010-11-03 02:56 冬瓜
            這個(gè)我知道,但它只能在windows下面運(yùn)行。而我的目標(biāo)是要在linux和windows下都能運(yùn)行。@陳梓瀚(vczh)
              回復(fù)  更多評(píng)論
              

            # re: 一則C++Unicode集與多字節(jié)轉(zhuǎn)換函數(shù)使用。 2010-11-05 09:52 天下
            獨(dú)立出來(lái)吧,不要綁定你的字符串類,
            項(xiàng)目中一般不用自定義的字符串類.

            還有.linux下有iconv這庫(kù).
              回復(fù)  更多評(píng)論
              

            # re: 一則C++Unicode集與多字節(jié)轉(zhuǎn)換函數(shù)使用。 2010-11-05 13:38
            你想要做全,就把UTF8和UTF32也做進(jìn)去。
            你這個(gè)設(shè)計(jì)的耦合性有問(wèn)題,你自己的字符串類型不應(yīng)該耦合在這樣的函數(shù)上。
            如果要跨平臺(tái),也應(yīng)該在不同的平臺(tái)上做不同的實(shí)現(xiàn)是最好的辦法。  回復(fù)  更多評(píng)論
              

            # re: 一則C++Unicode集與多字節(jié)轉(zhuǎn)換函數(shù)使用。 2010-11-05 16:13 冬瓜
            經(jīng)驗(yàn)與精力,都有限。主要的要求,滿足我在windows和linux下開(kāi)發(fā)即可。@釀
              回復(fù)  更多評(píng)論
              

            # re: 一則C++Unicode集與多字節(jié)轉(zhuǎn)換函數(shù)使用。 2010-11-05 16:18 冬瓜
            我這個(gè)是做到與這個(gè)微型庫(kù)一起的,獨(dú)立出來(lái),沒(méi)有什么意義。
            這個(gè)函數(shù),沒(méi)有與我的字符串綁定,連std::string都沒(méi)有一起綁定。StringCopy是一個(gè)字符串復(fù)制函數(shù),在Release下面經(jīng)優(yōu)化后,比strcpy還要快。
            @天下
              回復(fù)  更多評(píng)論
              

            亚洲欧美一级久久精品| 国产精品99久久久精品无码| 亚洲一区中文字幕久久| 久久国产高清一区二区三区| 久久久久av无码免费网| 国产巨作麻豆欧美亚洲综合久久| 久久久久亚洲精品天堂久久久久久| 人妻无码精品久久亚瑟影视 | 久久精品国产精品亚洲下载 | 亚洲?V乱码久久精品蜜桃 | 国产精品久久久久久久久免费 | 亚洲av日韩精品久久久久久a| 久久九九亚洲精品| 久久久久精品国产亚洲AV无码| 久久精品成人国产午夜| 成人久久免费网站| 一本色道久久88综合日韩精品| 久久精品中文字幕久久| 久久精品无码一区二区无码 | 免费精品久久天干天干| 久久99精品久久久久久水蜜桃| 97久久天天综合色天天综合色hd| 久久这里有精品| 久久久99精品一区二区 | 国产69精品久久久久观看软件| 国产精品美女久久久免费| 国产成人久久激情91| 丁香五月网久久综合| 久久久久久综合一区中文字幕 | 久久无码专区国产精品发布| 国产综合成人久久大片91| 99热都是精品久久久久久| 99久久精品免费| 久久久久这里只有精品| 久久久久人妻精品一区三寸蜜桃| 久久久久国色AV免费观看 | 久久婷婷国产剧情内射白浆 | 超级97碰碰碰碰久久久久最新 | 亚洲人成精品久久久久| 久久久久人妻一区二区三区| 精品久久久久久国产|