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

            四虎影视久久久免费观看| 久久久久久久波多野结衣高潮| 久久综合香蕉国产蜜臀AV| 久久久女人与动物群交毛片| 久久天堂电影网| 久久精品国产99国产精品亚洲| 国产精品青草久久久久婷婷| 天天影视色香欲综合久久| 久久99精品久久久久久hb无码 | 日韩人妻无码一区二区三区久久| AV无码久久久久不卡蜜桃| 无码人妻少妇久久中文字幕| 久久99国产乱子伦精品免费| 亚洲欧洲久久久精品| 亚洲国产成人久久精品动漫| 日韩精品久久久肉伦网站| 久久久高清免费视频| 人妻少妇精品久久| 国产无套内射久久久国产| 国产精品禁18久久久夂久| 亚洲国产欧洲综合997久久| 一级女性全黄久久生活片免费 | 一本大道加勒比久久综合| 色婷婷综合久久久中文字幕 | 国内精品九九久久久精品| 久久精品国产日本波多野结衣| 色播久久人人爽人人爽人人片aV| 国产精品九九久久免费视频 | 99久久婷婷国产综合精品草原| 97久久精品人妻人人搡人人玩| 人妻无码中文久久久久专区| 久久久这里有精品| 久久天天躁狠狠躁夜夜2020一| 久久久久久免费视频| 热久久最新网站获取| 午夜精品久久久内射近拍高清| 久久综合精品国产一区二区三区| 久久最新免费视频| 国内精品久久久久影院老司| 国产精品乱码久久久久久软件| 伊人久久综合成人网|