青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Khan's Notebook GCC/GNU/Linux Delphi/Window Java/Anywhere

路漫漫,長(zhǎng)修遠(yuǎn),我們不能沒有錢
隨筆 - 173, 文章 - 0, 評(píng)論 - 257, 引用 - 0
數(shù)據(jù)加載中……

STL Vector 的遍歷刪除.

Vector 其實(shí)就類似動(dòng)態(tài)數(shù)組. 事先分配好一定量的內(nèi)存. 當(dāng)需要的內(nèi)存值大于某個(gè)閥值. 就重新申請(qǐng)內(nèi)存. 重新分配. 當(dāng)小于某個(gè)閥值, 也會(huì)導(dǎo)致重新分配.(自動(dòng)收縮部分, stl沒有明確規(guī)定, 有些庫實(shí)現(xiàn)了)

正確: code1
      vector<string> vecFiles;
      vector<string>::iterator  it_pos;
      //@todo 已下載文件過濾
      for (it_pos = vecFiles.begin(); it_pos != vecFiles.end(); ) {
        string strTmp = *it_pos;
        if( objDownHis.checkHisList( strTmp.c_str() ) ){ //判斷是否已下載過, 已下載則從列表刪除
          g_Log << TIME << "file:[" << *it_pos << "] found "<< END; //
          vecFiles.erase(it_pos++);
        }else
          it_pos++;
      }


正確: code2
      vector<string> vecFiles;
      vector<string>::iterator  it_pos;
      //@todo 已下載文件過濾
      for (it_pos = vecFiles.begin(); it_pos != vecFiles.end(); ) { 
        string strTmp = *it_pos;
        if( objDownHis.checkHisList( strTmp.c_str() ) ){ //判斷是否已下載過, 已下載則從列表刪除
          g_Log << TIME << "file:[" << *it_pos << "] found "<< END; //
          it_pos = vecFiles.erase(it_pos);
        }else
          it_pos++;
      }

錯(cuò)誤: code3
      vector<string> vecFiles;
      vector<string>::iterator  it_pos;
      //@todo 已下載文件過濾
      for (it_pos = vecFiles.begin(); it_pos != vecFiles.end(); it_pos++) { 
        string strTmp = *it_pos;
        if( objDownHis.checkHisList( strTmp.c_str() ) ){ //判斷是否已下載過, 已下載則從列表刪除
          g_Log << TIME << "file:[" << *it_pos << "] found "<< END; //
          vecFiles.erase(it_pos);
        }
      }


code3 錯(cuò)誤的原因?yàn)? vecFiles.erase(it_pos); 當(dāng)前的it_pos已經(jīng)被刪除了, 再下一次循環(huán)的時(shí)候 it_pos++, 訪問非法內(nèi)存..

然后回過頭來看code1, vecFiles.erase(it_pos++); 在當(dāng)前的it_pos已經(jīng)被刪除的時(shí)候, it_pos已經(jīng)指向下一個(gè)位置了. 雖然這里邏輯上是錯(cuò)誤的. 但是利用c語法的特性產(chǎn)生了一個(gè)正確的結(jié)果, 算是一個(gè)技巧. 不算是一門技術(shù).

code2, it_pos = vecFiles.erase(it_pos); erase刪除的時(shí)候, 也返回了下一個(gè)指針的位置,我們將這個(gè)位置保留了, 所以這種做法也是正確的.


另外一個(gè)移植性比較好的做法是remove_if 和一個(gè)仿函數(shù).

仿函數(shù)可以是:
struct check {
    check( Object * objDownHis ) : m_obj( objDownHis ) {}
    check( const check & c ) : m_obj( c.m_obj ) {}

    bool operator()(const string & s) const {
       if ( m_obj->checkHisList( s.c_str() ) {
            g_Log .........
            return true;
       }
       return false;
    }
    Object * m_obj;
};

vecFiles.erase( std::remove_if( vecFile.begin(), vecFile.end(), check( &objDownHis ) );


鳴謝p大, lancey, jackz 排名不分先后.. 全按交流時(shí)間順序...

posted on 2009-12-08 13:29 Khan 閱讀(6217) 評(píng)論(5)  編輯 收藏 引用 所屬分類: GCC/G++跨平臺(tái)開發(fā)

評(píng)論

# re: STL Vector 的遍歷刪除.  回復(fù)  更多評(píng)論   

>code3 錯(cuò)誤的原因?yàn)? vecFiles.erase(it_pos); 當(dāng)前的it_pos已經(jīng)被刪除
>了, 再下一次循環(huán)的時(shí)候 it_pos++, 訪問非法內(nèi)存..

>然后回過頭來看code1, vecFiles.erase(it_pos++); 在當(dāng)前的it_pos已經(jīng)被
>刪除的時(shí)候, it_pos已經(jīng)指向下一個(gè)位置了. 雖然這里邏輯上是錯(cuò)誤的. 但是利
>用c語法的特性產(chǎn)生了一個(gè)正確的結(jié)果, 算是一個(gè)技巧. 不算是一門技術(shù).

我對(duì)這種的說法有不同看法:
it_pos無所謂刪除不刪除,it_pos 的行為就像指針一樣,指針本身不會(huì)被刪除,被刪除的是指針指向的內(nèi)容。我想樓主可能對(duì)迭代器失效的理解有偏差(建議在網(wǎng)上查一查相關(guān)的資料再看看)
我覺得,code1、2、3沒有什么本質(zhì)區(qū)別,都有可能產(chǎn)生迭代器失效的問題。
一個(gè)原則:對(duì)vector只要做了刪除或是增加動(dòng)作,就要示迭代器已經(jīng)無效,必須重新從vector對(duì)象獲取新的迭代器的值,而不能用臨時(shí)變量、后綴自增等方法……
remove_if+erase的版本才是可讀性最好且沒什么問題的。

個(gè)人愚見,請(qǐng)博主笑納……



2009-12-08 18:43 | 唐風(fēng)

# re: STL Vector 的遍歷刪除.  回復(fù)  更多評(píng)論   

傻傻的開發(fā)的
2009-12-10 10:23 | 夢(mèng)芭莎內(nèi)衣

# re: STL Vector 的遍歷刪除.  回復(fù)  更多評(píng)論   

code1的做法: 對(duì)非連續(xù)內(nèi)存容器是可行的 對(duì)連續(xù)內(nèi)存容器是不可取的
code1中會(huì)出現(xiàn)漏刪 而不是內(nèi)存越界
2009-12-10 17:45 | yisa

# re: STL Vector 的遍歷刪除.  回復(fù)  更多評(píng)論   

@yisa

我用代碼驗(yàn)證了下,的確是這樣:
歡迎去我的空間討論交流 hi.baidu.com/bmrs
1 /*
2 DATE: 2010.6.25
3 內(nèi)容:關(guān)于vector的遍歷刪除
4 任何改變 vector 長(zhǎng)度的操作都會(huì)使已存在的迭代器失效。例如,在調(diào)用 push_back 之后,就不能再信賴指向 vector 的迭代器的值了。
5 */
6 #include <iostream>
7 #include <vector>
8 #include <string>
9 #include <cstring>
10 using namespace std;
11
12 typedef vector<int> V;
13 typedef vector<int>::iterator VIT;
14 V v1;
15
16
17 int main()
18 {
19 for(int i=0; i<10; ++i)
20 v1.push_back(i);
21
22 VIT it = v1.begin();
23 VIT it2;
24 for(; it!=v1.end(); ++it)
25 cout<<*it<<" ";
26 cout<<endl<<v1.end()-v1.begin()<<endl; //vector容器的iterator是支持加減操作的,這在其他類型的迭代器中很少見
27 VIT it0 = v1.begin()+1; // 1
28 it2 = v1.begin()+3; // 3
29 VIT it3 = it2+1; // 4
30 cout<<"*it0="<<*it0<<" *it2="<<*it2<<" *it3="<<*it3<<endl;
31
32 for(it=v1.begin(); it!=v1.end(); ++it)
33 {
34 if(*it == 3)
35 {
36 cout<<"in for: before erase,*it="<<*it<<endl;
37 VIT tmp = it;
38 VIT r = v1.erase(it++);
39 cout<<"in for: after erase,*tmp="<<*tmp<<endl;
40 cout<<"in for: after it++ ,*it="<<*it<<endl;
41 cout<<"in for: after erase,*r="<<*r<<endl;
42 if(r == tmp)
43 cout<<"A random access iterator pointing to the new location of the element that followed the last element erased by the function call, which is the vector end if the operation erased the last element in the sequence."<<endl;
44 break;
45 }
46 }
47
48 cout<<"*it0="<<*it0<<" *it2="<<*it2<<" *it3="<<*it3<<endl;
49 return 0;
50 }
2010-06-25 16:04 | glq

# re: STL Vector 的遍歷刪除.  回復(fù)  更多評(píng)論   

的說法是的范德薩阿士發(fā)送到發(fā)送到大夫阿士大夫士大夫士大夫撒大撒的
2015-06-12 17:07 | 、開開
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩免费精品| 久久久久久久综合狠狠综合| 欧美人牲a欧美精品| 亚洲伦理在线观看| 亚洲激情视频在线| 欧美精品久久一区二区| 在线视频欧美日韩| 亚洲一区二区三区乱码aⅴ| 国产精品性做久久久久久| 久久视频在线视频| 免费成人高清| 亚洲午夜久久久久久尤物 | 国外精品视频| 亚洲第一精品夜夜躁人人爽| 欧美日韩高清免费| 欧美一区二区三区视频免费播放| 午夜欧美精品| 在线看片第一页欧美| 亚洲精品影院| 国产美女扒开尿口久久久| 免费看亚洲片| 欧美午夜精品久久久久久孕妇| 久久精品一区二区三区不卡牛牛 | 欧美黑人多人双交| 欧美一区二区三区日韩视频| 欧美日本高清视频| 国产欧美在线播放| 欧美不卡一区| 国产精品久久久久久久浪潮网站 | 欧美成人嫩草网站| 欧美视频免费在线观看| 久热精品视频在线| 国产精品久久毛片a| 免费日韩一区二区| 国产欧美日韩一区| 99re6这里只有精品| 伊人色综合久久天天五月婷| 一本大道久久精品懂色aⅴ| 亚洲高清色综合| 午夜日韩电影| 亚洲欧美韩国| 欧美精品国产| 嫩草伊人久久精品少妇av杨幂| 国产精品久久久999| 亚洲福利视频专区| 韩国免费一区| 香蕉国产精品偷在线观看不卡| 一区二区三区四区蜜桃| 美女图片一区二区| 久久人91精品久久久久久不卡| 国产精品v欧美精品∨日韩| 亚洲激情在线激情| 亚洲国产综合在线| 久久永久免费| 免费欧美电影| 樱桃国产成人精品视频| 性欧美xxxx大乳国产app| 午夜国产一区| 国产精品毛片va一区二区三区| 亚洲久色影视| 99视频精品全部免费在线| 欧美丰满少妇xxxbbb| 欧美国产一区二区| 亚洲国产婷婷| 欧美激情亚洲激情| 亚洲伦伦在线| 亚洲女优在线| 国产精品视频观看| 性久久久久久久久| 久久夜色精品国产噜噜av| 国产亚洲美州欧州综合国| 欧美中文日韩| 美女精品自拍一二三四| 亚洲东热激情| 欧美激情1区2区| 日韩视频一区二区三区| 亚洲一区二区三区欧美| 国产精品日韩精品欧美精品| 午夜久久黄色| 欧美成人按摩| av成人手机在线| 国产精品成人午夜| 香蕉久久夜色精品| 免费试看一区| 一区二区免费在线视频| 国产精品久久久久久久久免费 | 欧美一级在线播放| 国产伦精品一区二区| 欧美在线视频在线播放完整版免费观看 | 欧美色图一区二区三区| 亚洲午夜电影| 久久综合九色99| 亚洲全部视频| 欧美性天天影院| 久久精品国产69国产精品亚洲| 欧美激情亚洲自拍| 亚洲视频999| 韩国免费一区| 欧美色图麻豆| 久久国产精品99国产精| 亚洲人成亚洲人成在线观看| 午夜精品福利一区二区三区av| 国产尤物精品| 欧美日韩一本到| 久久九九免费| 亚洲色图制服丝袜| 免费中文日韩| 久久av一区二区三区漫画| 亚洲品质自拍| 黄网站免费久久| 欧美日韩一级黄| 久久久久久有精品国产| 一二三四社区欧美黄| 欧美成人免费全部| 性欧美超级视频| 亚洲午夜91| 亚洲国产一区二区a毛片| 国产日本欧洲亚洲| 欧美日韩一区视频| 你懂的视频欧美| 欧美一区高清| 亚洲天堂成人| av不卡在线观看| 女人色偷偷aa久久天堂| 久久精品论坛| 欧美一区二区三区免费大片| 亚洲美女免费精品视频在线观看| 国语自产在线不卡| 国产麻豆9l精品三级站| 欧美午夜电影在线| 欧美麻豆久久久久久中文| 久久男人av资源网站| 久久福利毛片| 欧美一区二区三区在线观看视频| 亚洲视频二区| 一区二区三区四区国产| 91久久精品一区二区别| 亚洲第一福利在线观看| 欧美大片免费| 欧美高清视频在线播放| 免费日韩成人| 欧美国产丝袜视频| 欧美丰满高潮xxxx喷水动漫| 欧美aⅴ99久久黑人专区| 欧美mv日韩mv国产网站app| 久久人人九九| 欧美成人蜜桃| 亚洲第一免费播放区| 亚洲第一在线综合在线| 欧美激情免费在线| 亚洲二区视频| 亚洲巨乳在线| 亚洲特级片在线| 欧美一级视频免费在线观看| 久久国产精品99久久久久久老狼| 欧美在线一二三四区| 久久免费99精品久久久久久| 久久午夜精品一区二区| 欧美成人免费网站| 欧美精品v国产精品v日韩精品| 久久蜜桃香蕉精品一区二区三区| 亚洲国产美女| 99成人在线| 亚洲一区二区三区视频| 久久av在线| 欧美www视频在线观看| 亚洲欧洲精品一区二区| 亚洲视频一区在线| 久久精彩视频| 欧美老女人xx| 国产日韩在线亚洲字幕中文| 在线成人免费视频| 99xxxx成人网| 久久精品一区四区| 亚洲欧洲精品成人久久奇米网| 亚洲天堂成人| 久久婷婷人人澡人人喊人人爽| 欧美理论电影在线播放| 国产伦精品一区二区三区免费 | 欧美精品久久久久久| 国产精品免费福利| 亚洲国产欧美一区二区三区同亚洲 | 亚洲国产高清一区| 亚洲视频每日更新| 看片网站欧美日韩| 国产精品高潮呻吟视频| 亚洲高清资源综合久久精品| 亚洲欧美美女| 欧美激情性爽国产精品17p| 亚洲色无码播放| 免费欧美网站| 国产日韩精品一区| 亚洲最新色图| 毛片一区二区| 亚洲一区二区日本| 欧美精品99| 亚洲精美视频| 久久久999| 亚洲欧美日韩中文视频| 欧美日韩午夜精品|