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

            不會(huì)飛的鳥

            2010年12月10日 ... 不鳥他們?。?! 我要用自己開發(fā)的分布式文件系統(tǒng)、分布式調(diào)度系統(tǒng)、分布式檢索系統(tǒng), 做自己的搜索引擎?。?!大魚有大志?。?! ---楊書童

            【轉(zhuǎn)】STL_string的字符串替換函數(shù)

            標(biāo)準(zhǔn)C++中的string中的函數(shù)不多,沒有CString的功能強(qiáng)大,但是如果想在Unicode編碼下使用多字節(jié),就不能使用CString,于是自己寫了一個(gè)類似于CString的Replace函數(shù)。
            string replace( const string& inStr, const char* pSrc, const char* pReplace )
            {
                 string str = inStr;
                string::size_type stStart = 0;
                string::iterator iter = str.begin();
                while( iter != str.end() )
                {
                    // 從指定位置 查找下一個(gè)要替換的字符串的起始位置。
                    string::size_type st = str.find( pSrc, stStart );
                    if ( st == str.npos )
                    {
                        break;
                    }
                    iter = iter + st - stStart;
                    // 將目標(biāo)字符串全部替換。
                    str.replace( iter, iter + strlen( pSrc ), pReplace );
                    iter = iter + strlen( pReplace );
                    // 替換的字符串下一個(gè)字符的位置
                    stStart = st + strlen( pReplace );
                }
                return str;
            }

            上述方法在執(zhí)行replace( "h h h h h h h h h h h h h h h h h h h ", " ", " " )時(shí)出現(xiàn)問題。
            下面再列出一種方法:
            string CComFunc::replace( const string& inStr, const char* pSrc, const char* pReplace )
            {
                string strSrc = inStr;
                string::size_type pos=0;      
                string::size_type srclen = strlen( pSrc );       
                string::size_type dstlen = strlen( pReplace );       
                while( (pos=strSrc.find(pSrc, pos)) != string::npos)
                {               
                    strSrc.replace(pos, srclen, pReplace);               
                    pos += dstlen;       
                }
                return strSrc;
            }

            補(bǔ)充,經(jīng)過測(cè)試,上面方法再執(zhí)行,replace( “暴”, "\\","==" )時(shí),依然會(huì)遇到問題。
            在日文系統(tǒng)上,因?yàn)?#8220;暴”占兩個(gè)字節(jié),而"\\"只占一個(gè)字節(jié),但與“暴”的低位字節(jié)ASCII碼相同。
            而string的Find函數(shù),是按照字節(jié)比較的,所以,將這個(gè)字節(jié)替換了,導(dǎo)致文本替換出現(xiàn)問題。
            于是考慮到不應(yīng)該按字節(jié)比較,應(yīng)該按字符比較,測(cè)試發(fā)現(xiàn),CString的替換函數(shù)沒有問題,于是考慮按照CString的方法重新寫一個(gè)replace函數(shù)。
            代碼如下:
            因?yàn)镃String在_MBCS和_UNICODE下是變寬的,而我寫的replace函數(shù),只針對(duì)string。
            string CComFunc::replace( const string& inStr, const char* pSrc, const char* pReplace )
            {
                string strSrc = inStr;
                LPSTR lpch = ( CHAR* )strSrc.c_str();
                int   nOldLength = strlen( lpch );
                int    nSourceLen = strlen(pSrc);
                if (nSourceLen == 0)
                {
                    return lpch;
                }
                int   nReplacementLen = strlen(pReplace);
                LPSTR lpszStart = lpch;
                LPSTR lpszEnd = lpszStart + nOldLength;
                LPSTR lpszTarget;

                // 先列出判斷替換字符是否存在的方法, 但在此函數(shù)中不使用這段代碼。
            /*
                // judge whether exist
                while (lpszStart < lpszEnd)
                {
                    while ((lpszTarget = (CHAR*)_mbsstr(( const unsigned char * )lpszStart, ( const unsigned char * )pSrc)) != NULL)
                    {
                        nCount++;
                        lpszStart = lpszTarget + nSourceLen;
                    }
                    lpszStart += strStart.length() + 1;
                }
                *//
               
                // 下面是替換的代碼。
                while (lpszStart < lpszEnd)
                {
                    while ((lpszTarget = (CHAR*)_mbsstr(( const unsigned char * )lpszStart, ( const unsigned char * )pSrc)) != NULL)
                    {
                        int nBalance = nOldLength - (lpszTarget - lpch + nSourceLen);
                        memmove(lpszTarget + nReplacementLen, lpszTarget + nSourceLen,
                            nBalance * sizeof(CHAR));
                        memcpy(lpszTarget, pReplace, nReplacementLen*sizeof(CHAR));
                        lpszStart = lpszTarget + nReplacementLen;
                        lpszStart[nBalance] = '\0';
                        nOldLength += (nReplacementLen - nSourceLen);
                    }
                    lpszStart += strlen(lpszStart) + 1;
                }
                return lpch;
            }

            此方法最關(guān)鍵的是_mbsstr函數(shù),在"MBSTRING.H"頭文件中聲明。

            posted on 2012-10-26 16:20 不會(huì)飛的鳥 閱讀(1465) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            成人国内精品久久久久影院| 久久国产精品一国产精品金尊| 久久精品国产91久久麻豆自制| 精品一区二区久久久久久久网站| 久久久精品一区二区三区| av无码久久久久久不卡网站| 久久91精品国产91久久麻豆| 久久综合九色欧美综合狠狠 | 亚洲精品第一综合99久久| 久久SE精品一区二区| 久久久久亚洲AV无码永不| 久久久久国产精品麻豆AR影院 | 久久久精品人妻一区二区三区蜜桃| 色狠狠久久AV五月综合| 国产高清国内精品福利99久久| 久久午夜无码鲁丝片秋霞| 久久成人影院精品777| 天天影视色香欲综合久久| 丁香五月网久久综合| 佐藤遥希在线播放一二区 | 99久久精品影院老鸭窝| 久久综合久久美利坚合众国| 国产精品欧美久久久天天影视| 欧美与黑人午夜性猛交久久久| 99国产欧美精品久久久蜜芽| 一级做a爰片久久毛片免费陪| 国产高潮国产高潮久久久| 97久久婷婷五月综合色d啪蜜芽| 成人资源影音先锋久久资源网| 狠狠色婷婷久久一区二区| 老司机午夜网站国内精品久久久久久久久| 色妞色综合久久夜夜| 久久99精品久久久大学生| 精品久久久久久无码不卡| 久久无码国产| 一级A毛片免费观看久久精品| 久久涩综合| 四虎久久影院| yy6080久久| 五月丁香综合激情六月久久| 中文字幕人妻色偷偷久久 |