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

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            內(nèi)存搜索與解析

            char*            MemFind(const void* src_buf, int src_len, const void* find_buf, int find_len);
            BOOL            ParserMem(const void* src_buf, int src_len, const vector< vector<char> >& vec_par, vector< vector<char> >& vec_result);//---- 多重二進(jìn)制分割
            BOOL            ParserMem(const void* src_buf, int src_len, const vector<char>& vec_par, vector< vector<char> >& vec_result);//---- 單層二進(jìn)制分割
            BOOL            ParserMem(const void* src_buf, int src_len, const char* par_buf, vector< vector<char> >& vec_result);//---- 字符分割
            BOOL            ParserMem(const void* src_buf, int src_len, const char* par_buf, vector<string>& vec_result);//---- 字符分割

             

            char* Glob_Fun::MemFind(const void* src_buf, int src_len, const void* find_buf, int find_len)
            {
                if ((NULL == src_buf) || (NULL == find_buf)
                    || (src_len <= 0) || (find_len <= 0))
                    return NULL;

                char*cp = (char*)src_buf;
                char*src_end = (char*)src_buf +  src_len;
                char*find_end = (char*)find_buf + find_len;
                char*s_src = NULL, *s_find = NULL;
                while (cp < src_end)
                {
                    s_src = cp;
                    s_find = (char*)find_buf;
                    while (s_src < src_end && s_find < find_end && *s_src == *s_find)
                        ++s_src, ++s_find;
                    if (s_find == find_end)
                        return(cp);
                    ++cp;
                }
                return(NULL);
            }

            BOOL Glob_Fun::ParserMem(
                                     const void*                    src_buf,
                                     int                            src_len,
                                     const vector< vector<char> >&    vec_par,
                                     vector< vector<char> >&        vec_result)
            {
                if ((NULL == src_buf) || (src_len <= 0) || vec_par.size() <= 0)
                    return FALSE;
                for (size_t t = 0; t < vec_par.size(); ++t)
                {
                    if(0 >= vec_par[t].size())
                        return FALSE;
                }

                vec_result.clear();

                vector<char> vec_tmp;
                BOOL bMatched = FALSE;
                int nParCount = vec_par.size();
                int nParTick = 0;
                char*cp = (char*)src_buf;
                char*src_end = (char*)src_buf +  src_len;
                int  nParLen = (int)vec_par[0].size();
                char*find_buf = (char*)&(vec_par[0][0]);
                char*find_end = find_buf + nParLen;
                char*s_src = NULL, *s_find = NULL;

                while (cp < src_end)
                {
                    s_src = cp;
                    s_find = (char*)find_buf;
                    while (s_src < src_end && s_find < find_end && *s_src == *s_find)
                        ++s_src,++s_find;
                    if (s_find == find_end)
                    {   
                        bMatched = TRUE;
                        cp += nParLen;
                        vec_result.push_back(vec_tmp);
                        vec_tmp.clear();
                        ++nParTick;
                        if(nParCount == nParTick)
                            nParTick = 0;
                        nParLen = (int)(vec_par[nParTick].size());
                        find_buf = (char*)&(vec_par[nParTick][0]);
                        find_end = find_buf + nParLen;            
                    }
                    else
                    {
                        vec_tmp.push_back(*cp);
                        ++cp;
                    }
                }
                if(TRUE == bMatched)
                    vec_result.push_back(vec_tmp);
                return(bMatched);
            }

            BOOL Glob_Fun::ParserMem(
                                     const void*                    src_buf,
                                     int                            src_len,
                                     const vector<char>&            vec_par,
                                     vector< vector<char> >&        vec_result)
            {
                if ((NULL == src_buf) || (src_len <= 0) || vec_par.size() <= 0)
                    return FALSE;
                vec_result.clear();

                vector<char> vec_tmp;
                BOOL bMatched = FALSE;
                char*cp = (char*)src_buf;
                char*src_end = (char*)src_buf +  src_len;
                int  nParLen = (int)vec_par.size();
                char*find_buf = (char*)&(vec_par[0]);
                char*find_end = find_buf + nParLen;
                char*s_src = NULL, *s_find = NULL;

                while (cp < src_end)
                {
                    s_src = cp;
                    s_find = (char*)find_buf;
                    while (s_src < src_end && s_find < find_end && *s_src == *s_find)
                        ++s_src, ++s_find;
                    if (s_find == find_end)
                    {   
                        bMatched = TRUE;
                        cp += nParLen;
                        vec_result.push_back(vec_tmp);
                        vec_tmp.clear();        
                    }
                    else
                    {
                        vec_tmp.push_back(*cp);
                        ++cp;
                    }
                }
                if(TRUE == bMatched)
                    vec_result.push_back(vec_tmp);
                return(bMatched);
            }

            BOOL Glob_Fun::ParserMem(
                                     const void*                    src_buf,
                                     int                            src_len,
                                     const char*                    par_buf,
                                     vector< vector<char> >&        vec_result)
            {
                if ((NULL == src_buf) || (src_len <= 0) || strlen(par_buf) <= 0)
                    return FALSE;
                vec_result.clear();

                vector<char> vec_tmp;
                BOOL bMatched = FALSE;
                char*cp = (char*)src_buf;
                char*src_end = (char*)src_buf +  src_len;
                int  nParLen = strlen(par_buf);
                char*find_buf = (char*)par_buf;
                char*find_end = find_buf + nParLen;
                char*s_src = NULL, *s_find = NULL;

                while (cp < src_end)
                {
                    s_src = cp;
                    s_find = (char*)find_buf;
                    while (s_src < src_end && s_find < find_end && *s_src == *s_find)
                        ++s_src, ++s_find;
                    if (s_find == find_end)
                    {   
                        bMatched = TRUE;
                        cp += nParLen;
                        vec_result.push_back(vec_tmp);
                        vec_tmp.clear();        
                    }
                    else
                    {
                        vec_tmp.push_back(*cp);
                        ++cp;
                    }
                }
                if(TRUE == bMatched)
                    vec_result.push_back(vec_tmp);
                return(bMatched);
            }

            BOOL Glob_Fun::ParserMem(
                                     const void*                    src_buf,
                                     int                            src_len,
                                     const char*                    par_buf,
                                     vector<string>&                vec_result)
            {
                if ((NULL == src_buf) || (src_len <= 0) || strlen(par_buf) <= 0)
                    return FALSE;
                vec_result.clear();

                string vec_tmp;
                BOOL bMatched = FALSE;
                char*cp = (char*)src_buf;
                char*src_end = (char*)src_buf +  src_len;
                int  nParLen = strlen(par_buf);
                char*find_buf = (char*)par_buf;
                char*find_end = find_buf + nParLen;
                char*s_src = NULL, *s_find = NULL;

                while (cp < src_end)
                {
                    s_src = cp;
                    s_find = (char*)find_buf;
                    while (s_src < src_end && s_find < find_end && *s_src == *s_find)
                        ++s_src, ++s_find;
                    if (s_find == find_end)
                    {   
                        bMatched = TRUE;
                        cp += nParLen;
                        vec_result.push_back(vec_tmp);
                        vec_tmp.clear();        
                    }
                    else
                    {
                        vec_tmp.push_back(*cp);
                        ++cp;
                    }
                }
                if(TRUE == bMatched)
                    vec_result.push_back(vec_tmp);
                return(bMatched);
            }

            posted on 2008-06-23 15:43 肥仔 閱讀(1697) 評論(1)  編輯 收藏 引用 所屬分類: 庫 & 代碼段

            評論

            # re: 內(nèi)存搜索與解析[未登錄]  回復(fù)  更多評論   

            good
            2009-04-20 16:38 | a
            久久精品国产男包| 亚洲精品高清一二区久久| 久久精品国产亚洲AV大全| 久久久久AV综合网成人| 99久久er这里只有精品18| 国产真实乱对白精彩久久| 久久人人爽人人爽人人片AV麻烦| 欧美熟妇另类久久久久久不卡| 亚洲一区二区三区日本久久九| 一级女性全黄久久生活片免费| 国产成人无码久久久精品一| 国产亚洲成人久久| 麻豆成人久久精品二区三区免费| 99热精品久久只有精品| 亚洲人成精品久久久久| 欧美午夜A∨大片久久| 丁香狠狠色婷婷久久综合| 精品国产乱码久久久久久呢| 久久亚洲国产成人影院网站| 欧美综合天天夜夜久久| 久久精品无码午夜福利理论片 | 久久综合九色综合欧美狠狠| 伊人色综合久久天天网| 91精品国产高清久久久久久国产嫩草 | 精品免费久久久久国产一区| 久久国产精品无码一区二区三区| 久久久噜噜噜久久| 国内精品久久久久久久coent| 99久久久国产精品免费无卡顿| 亚洲国产精品18久久久久久| 国产精品一区二区久久精品涩爱| 久久久久亚洲爆乳少妇无| 狠狠色丁香婷婷综合久久来来去| 999久久久免费精品国产| 久久久久亚洲AV无码专区体验| 久久久无码精品亚洲日韩京东传媒| 久久人人爽人人爽人人片AV东京热| 国产成人久久精品二区三区| 国产精自产拍久久久久久蜜| 成人国内精品久久久久影院VR| 国产99久久久久久免费看|