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

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

            關于stl 迭代器失效

            先看兩條規制:

            1
            ,對于節點式容器(map, list, set)元素的刪除,插入操作會導致指向該元素的迭代器失效,其他元素迭代器不受影響

            2
            ,對于順序式容器(vector)元素的刪除、插入操作會導致指向該元素以及后面的元素的迭代器失效


            常見的錯誤代碼示例:

            1clip_image001struct sMem
            2clip_image002{
            3clip_image003    int m_i;
            4clip_image003    sMem(int i = 10)
            5    clip_image002{
            6clip_image003        m_i = i;
            7clip_image004    }
            8clip_image003
            9clip_image003    int GetI()
            10    clip_image002{
            11clip_image003        return m_i;
            12clip_image004    }
            13clip_image005};

            1clip_image001
            2clip_image001typedef vector<sMem*> sMemList;
            3clip_image001typedef vector<sMem*>::iterator sIT;
            4clip_image001sMemList MemList;

            1clip_image001    // 迭代器失效
            2clip_image001    for (sIT it = MemList.begin(); it != MemList.end(); ++it)
            3    clip_image002{
            4clip_image003        if ((*it)->GetI() == 10)
            5clip_image003            MemList.erase(it);
            6clip_image003        else
            7        clip_image002{
            8clip_image003            printf("%d:%d\n", i++, (*it)->GetI());
            9clip_image004        }
            10clip_image005    }


            兩種解決方法:
            對于順序容器:

            clip_image001
            clip_image001
            bool Equal10(sMem* pMem)
            clip_image002{

                return pMem->GetI() == 10 ? true : false;
            }

            1clip_image001MemList.erase(remove_if(MemList.begin(), MemList.end(), Equal10));


            對于結點容器:

            1clip_image001    for (sIT it = MemList.begin();
            2clip_image001        it != MemList.end(); )
            3    clip_image002{
            4        if ((*it).second->GetI() == 10)
            5            MemList.erase(it++);
            6        else
            7        clip_image002{
            8            printf("%d:%d\n", i++, (*it).second->GetI());
            9            it++;
            10        }
            11    }

             

            posted on 2009-07-09 14:48 肥仔 閱讀(1564) 評論(0)  編輯 收藏 引用 所屬分類: Boost & STL

            狠狠色噜噜色狠狠狠综合久久| 久久本道综合久久伊人| 久久婷婷午色综合夜啪| 免费精品国产日韩热久久| 久久午夜夜伦鲁鲁片免费无码影视| 狠狠狠色丁香婷婷综合久久五月| 国产精品美女久久久久av爽 | 亚洲色大成网站www久久九| 婷婷久久香蕉五月综合加勒比| 久久亚洲国产成人影院网站| 久久久精品国产sm调教网站| 亚洲国产成人精品女人久久久| 久久久久99精品成人片| 国产成人久久激情91| 久久精品午夜一区二区福利| 久久国产一区二区| 久久笫一福利免费导航 | 狠狠色婷婷久久一区二区 | 久久这里只精品国产99热| 久久亚洲中文字幕精品有坂深雪| 久久天天躁夜夜躁狠狠| 国内精品伊人久久久影院| 久久综合久久久| 蜜臀久久99精品久久久久久小说 | 国产精品久久久久久久app| 亚洲国产精品久久66| 久久精品国产欧美日韩| 久久综合久久综合九色| 久久精品国内一区二区三区| 97久久国产综合精品女不卡| 怡红院日本一道日本久久| 国产精品美女久久久m| 国产国产成人精品久久| 少妇被又大又粗又爽毛片久久黑人| 久久成人国产精品免费软件| 日日狠狠久久偷偷色综合免费 | 国产ww久久久久久久久久| 99久久婷婷国产一区二区| 久久人人爽人人爽人人片AV东京热| 中文字幕一区二区三区久久网站| 久久福利青草精品资源站免费|