• <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ù)加載中……

            使用std::vector的一個(gè)誤區(qū)

            借助valgrind,終于找到一個(gè)隱藏很久的bug:
            class A
            {
               
            }
            ;
            std::vector
            <A>  vecArray;

            vecArray.push_back( );
            vecArray.push_back( );
            vecArray.push_back( );

            A
            & a= vecArray.back();
            vecArray.push_back( );


            以上的代碼驟眼看上去也沒有什么奇怪的地方,經(jīng)過多次的測試也沒有發(fā)現(xiàn)什么問題。但昨天bug終于爆發(fā)了,程序總是無緣無故down掉。
            其實(shí)原因很簡單,就是在 A & a = vecArray.back(); 這一步。
            vector是一個(gè)會自增長的容器,自增長的結(jié)果就是把原來的內(nèi)存釋放掉,重新分配一個(gè)足夠大的內(nèi)存。既然原來的內(nèi)存已經(jīng)釋放掉,那么a所引用的內(nèi)存就是一段無效的內(nèi)存。對無效內(nèi)存的訪問,后果有多嚴(yán)重就不用多說了。

            想解決方法也很多,最簡單就是用std::list或者std::deque替代vector。
             
            ========================================================================================
             

            Comments

            • # re: 使用std::vector的一個(gè)誤區(qū)

              glacjay
              Posted @ 2005-11-09 22:06
              不可以保存索引嗎?必須要用指針嗎?為了效率?  回復(fù) 更多評論

            • # re: 使用std::vector的一個(gè)誤區(qū)

              cyt
              Posted @ 2005-11-10 09:23
              用索引是可以,不過個(gè)人不大喜歡用索引。其原因就是索引并不是stl容器所共有的特性,一旦使用了索引,以后如果需要轉(zhuǎn)換為其他容器的時(shí)候,未免需要改動不少地方。另外,我這里所說的只是一種解決方法。對于我這種情況,只需要更改一個(gè)typedef定義就可以解決問題。如果改成是用索引的話,需要更改不少地方,而且很容易會漏了。
              程序本身算法也比較復(fù)雜,相對來說使用索引性能也不會下降多少,這個(gè)倒不是什么需要考慮的地方了。  回復(fù) 更多評論

            • # re: 使用std::vector的一個(gè)誤區(qū)

              nilaozi
              Posted @ 2005-11-11 22:23
              最后一次評論。也夠出氣了!
              一個(gè)在blogjava失去家園的人聲討。
              除了政治原因可以刪了一個(gè)人blog,別的理由都不能成為理由。
              我為每個(gè)都到他們所需的ebook難道錯(cuò)了,
              貼到首頁,我還以你們有預(yù)申機(jī)制,CSDN是這樣,管理員認(rèn)為可以才放到首頁。
              不信你到他們的首頁看看。
              http://csdn.blog.net/ahhoo
              如果你認(rèn)為還不錯(cuò)的,請到回貼。
              回復(fù) 更多評論

            • # re: 使用std::vector的一個(gè)誤區(qū)

              blues
              Posted @ 2006-09-04 14:05
              vector和deque的差別是操作上的,list雖然是基于鏈表的,但是不能隨機(jī)訪問,任何的容器都不是完美的,而且使用指針必然要判斷,但也算是個(gè)bug,
              我想解決的話類型用boost的any應(yīng)該可以了,它本身帶有安全檢查,我沒試僅是建議  回復(fù) 更多評論

            • # re: 使用std::vector的一個(gè)誤區(qū)

              stl
              Posted @ 2008-10-06 01:03
              STL里的容器大部分都是“值”容器,你用“引用”去訪問容器里的內(nèi)容,錯(cuò)了正常。這不是vector的問題,你自己使用的問題。如果基于性能考慮上面的程序一定要使用“引用”語意的話,應(yīng)該用vector<A*>的寫法才比較正確。  回復(fù) 更多評論

            posted on 2008-10-16 13:28 肥仔 閱讀(794) 評論(0)  編輯 收藏 引用 所屬分類: Boost & STL

            日本久久中文字幕| 国产精品一久久香蕉产线看| 久久久久国产精品麻豆AR影院| 91精品国产91久久久久久| 久久精品国产一区二区三区| 一个色综合久久| 97精品伊人久久久大香线蕉| 亚洲七七久久精品中文国产| 国产精品禁18久久久夂久| 久久精品国产清自在天天线| 色欲久久久天天天综合网| 国产精品久久久久久久午夜片| 三上悠亚久久精品| 久久九色综合九色99伊人| 久久久噜噜噜久久熟女AA片| 亚洲国产精品一区二区三区久久| 久久久久成人精品无码中文字幕| 久久se精品一区精品二区国产| 久久国产精品一国产精品金尊| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久天天躁夜夜躁狠狠 | 久久国产综合精品五月天| 麻豆一区二区99久久久久| 久久综合鬼色88久久精品综合自在自线噜噜| 久久久无码精品亚洲日韩按摩 | 亚洲日本va中文字幕久久| 久久人人爽人人澡人人高潮AV| 久久综合综合久久97色| av无码久久久久不卡免费网站| 欧美日韩精品久久久久| 国产精品免费久久| 久久免费视频网站| 久久精品国产亚洲综合色| 97精品伊人久久大香线蕉app| 久久久久久毛片免费播放| 久久精品麻豆日日躁夜夜躁| 久久99国内精品自在现线| 久久久精品国产sm调教网站| 国内精品久久久久伊人av| 99久久免费国产精精品| 久久婷婷综合中文字幕|