• <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寫的函數(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 冬瓜 閱讀(4011) 評(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)論
              

            久久激情五月丁香伊人| 97久久国产露脸精品国产| 国产一区二区三区久久| 久久九九亚洲精品| 99国内精品久久久久久久| 欧美一区二区久久精品| 国产69精品久久久久777| 婷婷久久综合九色综合九七| 伊人久久大香线蕉亚洲| 久久青青草原精品影院| 久久精品成人欧美大片| 亚洲精品高清久久| 狼狼综合久久久久综合网| 久久国产综合精品五月天| 亚洲中文字幕无码一久久区 | 伊人色综合九久久天天蜜桃 | 久久夜色tv网站| 久久中文字幕人妻熟av女| 99久久免费只有精品国产| 久久精品中文无码资源站| 欧美激情一区二区久久久| 国产日韩久久免费影院| 一本色道久久88加勒比—综合| 97久久婷婷五月综合色d啪蜜芽| 久久影视国产亚洲| 久久精品国产欧美日韩| 91精品观看91久久久久久| 久久久久人妻精品一区二区三区 | 亚洲AV无码1区2区久久| 色狠狠久久综合网| 无码人妻久久一区二区三区蜜桃| 久久精品无码一区二区三区日韩 | 久久精品国产2020| 精品人妻伦九区久久AAA片69| 久久有码中文字幕| 久久婷婷是五月综合色狠狠| 三级片免费观看久久| 亚洲精品午夜国产va久久| 国产免费久久精品99re丫y| 久久久久亚洲AV无码专区首JN| 久久精品人人做人人爽电影 |