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

            不會飛的鳥

            2010年12月10日 ... 不鳥他們!!! 我要用自己開發的分布式文件系統、分布式調度系統、分布式檢索系統, 做自己的搜索引擎!!!大魚有大志!!! ---楊書童

            【轉】STL_string的字符串替換函數

            標準C++中的string中的函數不多,沒有CString的功能強大,但是如果想在Unicode編碼下使用多字節,就不能使用CString,于是自己寫了一個類似于CString的Replace函數。
            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() )
                {
                    // 從指定位置 查找下一個要替換的字符串的起始位置。
                    string::size_type st = str.find( pSrc, stStart );
                    if ( st == str.npos )
                    {
                        break;
                    }
                    iter = iter + st - stStart;
                    // 將目標字符串全部替換。
                    str.replace( iter, iter + strlen( pSrc ), pReplace );
                    iter = iter + strlen( pReplace );
                    // 替換的字符串下一個字符的位置
                    stStart = st + strlen( pReplace );
                }
                return str;
            }

            上述方法在執行replace( "h h h h h h h h h h h h h h h h h h h ", " ", " " )時出現問題。
            下面再列出一種方法:
            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;
            }

            補充,經過測試,上面方法再執行,replace( “暴”, "\\","==" )時,依然會遇到問題。
            在日文系統上,因為“暴”占兩個字節,而"\\"只占一個字節,但與“暴”的低位字節ASCII碼相同。
            而string的Find函數,是按照字節比較的,所以,將這個字節替換了,導致文本替換出現問題。
            于是考慮到不應該按字節比較,應該按字符比較,測試發現,CString的替換函數沒有問題,于是考慮按照CString的方法重新寫一個replace函數。
            代碼如下:
            因為CString在_MBCS和_UNICODE下是變寬的,而我寫的replace函數,只針對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;

                // 先列出判斷替換字符是否存在的方法, 但在此函數中不使用這段代碼。
            /*
                // 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;
            }

            此方法最關鍵的是_mbsstr函數,在"MBSTRING.H"頭文件中聲明。

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

            亚洲日本va中文字幕久久| 狠狠色丁香久久婷婷综合蜜芽五月 | 91精品国产乱码久久久久久| 国产精品久久久久aaaa| 女人香蕉久久**毛片精品| 国内精品伊人久久久久777| 久久久久亚洲AV成人片| 久久精品中文无码资源站| 91久久精品电影| 国产精品久久久久影视不卡| 久久久网中文字幕| 久久久久国产一区二区三区| 91精品国产综合久久四虎久久无码一级| 久久精品国产福利国产琪琪| 久久精品国产亚洲AV大全| 伊人久久成人成综合网222| 久久综合五月丁香久久激情| 亚洲精品无码久久久久| 无码人妻精品一区二区三区久久久| 久久久久久久99精品免费观看| 97视频久久久| 亚洲国产成人久久综合区| 久久国产精品成人免费| 亚洲国产精品久久66| 亚洲精品高清国产一线久久| 久久久免费观成人影院| 国产精品美女久久久网AV| 手机看片久久高清国产日韩| 国产精品成人久久久| 国产免费久久精品99久久| 91精品国产色综久久| 久久r热这里有精品视频| 久久99国产综合精品免费| 国产99久久久久久免费看| 免费观看成人久久网免费观看| 久久综合综合久久综合| 久久久久久狠狠丁香| 日韩欧美亚洲综合久久影院d3| 久久青草国产精品一区| 久久国产精品久久国产精品| 香蕉久久夜色精品国产小说|