• <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)貼],因其丑陋,見(jiàn)諒!~
            隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            使用std::vector 的陷阱

            在使用std的容器的時(shí)候,不少人喜歡用vector, 因?yàn)楸绕?span lang="EN-US">list,更省空間,而且可以根據(jù)index直接讀取某個(gè)值,而不用一個(gè)個(gè)枚舉來(lái)取.

            但是,std::vector確實(shí)有一些值得注意的陷阱, 這里先說(shuō)其中一個(gè), 請(qǐng)看以下代碼.

            std::vector< int >  values;

            values.push_back(1);

            values.push_back(2);

            values.push_back(3);

            values.erase(values.begin() + 1);

            乍看之下,這幾行簡(jiǎn)單的代碼沒(méi)什么 問(wèn)題. 實(shí)際執(zhí)行起來(lái), 還是沒(méi)什么問(wèn)題 , 但卻有一個(gè)陷阱. 由于例子里面用的是intvector,所以這樣做沒(méi)有任何問(wèn)題, ,假如不是一個(gè)int, 而是一個(gè)類(lèi),一個(gè)結(jié)構(gòu)體,類(lèi)或結(jié)構(gòu)體里面還有指針, 那就很可能出問(wèn)題了. why?

            因?yàn)?span lang="EN-US">vector不象list,vector始終要保持一個(gè)完整的內(nèi)存結(jié)構(gòu)(因?yàn)榫褪且粋€(gè)數(shù)組),這樣才可以讓values[1]這樣的方式正確運(yùn)行. 但是,如果要在vector中間刪掉一個(gè)成員的話(huà),vector是這樣做的, 先把該成員后面的一個(gè)成員,一直到最后一個(gè)成員往前一位置拷貝,這樣需要?jiǎng)h除的成員已經(jīng)被后面的覆蓋了, 然后再刪除最后一個(gè)成員,這樣,vector又能保持一段完整的內(nèi)存結(jié)構(gòu)了注意,因?yàn)樽詈笠粋€(gè)成員會(huì)被刪除,而如果這個(gè)成員里面有一個(gè)成員變量是指針, 那析構(gòu)函數(shù)很有可能會(huì)把這個(gè)指針指向的地方釋放掉這樣,即使最后一個(gè)成員被復(fù)制了一份 到倒數(shù)第2的位置,也因?yàn)樵谒旧肀粍h除的時(shí)候,把倒數(shù)第2個(gè)(也就是它的復(fù)制) 的指針成員所指向的地方給釋放了! 如圖:

                                  clip_image002

            解決的辦法也很簡(jiǎn)單, 最少有2. 1,  增加作為vector類(lèi)型的類(lèi)的拷貝構(gòu)造函數(shù), 因?yàn)?span lang="EN-US">vectorerase的時(shí)候會(huì)發(fā)生一次拷貝,讓拷貝構(gòu)造函數(shù)不單單是復(fù)制指針,還把指針?biāo)赶虻膬?nèi)容給拷貝一份,這樣就不會(huì)導(dǎo)致被最后一個(gè)成員釋放的時(shí)候一起釋放掉了. 2, 如果有引用記數(shù)的話(huà),如智能指針, 就不會(huì)被釋放掉了。不過(guò)如果一般編碼里面不需要用到引用記數(shù)的話(huà),還是方法1比較簡(jiǎn)便

             

            posted on 2009-09-02 22:36 肥仔 閱讀(7508) 評(píng)論(30)  編輯 收藏 引用 所屬分類(lèi): Boost & STL

            評(píng)論

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            不明白為什么成員變量是指針就把指針?biāo)傅牡胤轿鰳?gòu),是你的類(lèi)實(shí)現(xiàn)的問(wèn)題嗎?

            int *p1 = new int(1);
            int *p2 = p1;

            vector< int* > ivec;
            ivec.push_back(p1);
            ivec.push_back(p2);

            當(dāng)我把vector中的p2 erase掉之后,p1所指無(wú)物?
            2009-09-03 09:20 | nelson

            # re: 使用std::vector 的陷阱[未登錄](méi)  回復(fù)  更多評(píng)論   

            其實(shí)我覺(jué)得這不是vector給你設(shè)的“陷阱”,STL容器只有責(zé)任維護(hù)你給他的東西,但沒(méi)理由維護(hù)這個(gè)東西里面的東西。不僅僅是vector,STL所有的容器如果按你這種思維去用,都會(huì)出問(wèn)題:
            class Test
            {
            int *a;
            ~Test()
            {
            delete a;
            }
            };
            std::vector<Test> 維護(hù)Test::a其實(shí)應(yīng)該是你的責(zé)任。
            2009-09-03 13:37 | Kevin Lynx

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            所有容器里面都應(yīng)該只存儲(chǔ)簡(jiǎn)單數(shù)據(jù)結(jié)構(gòu),一旦數(shù)據(jù)結(jié)構(gòu)為復(fù)雜數(shù)據(jù)結(jié)構(gòu)時(shí),則應(yīng)該存儲(chǔ)該數(shù)據(jù)的指針。
            2009-09-15 16:55 | davidfan

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            Last time I downloaded the mp ringtones with the help of the <a href="http://www.milliontones.com">ringtones</a> site and used to be completely satisfied.
            2010-06-24 17:54 | ConnerThelma30

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            I think that you really know how not easy could the custom term paper creating be. But, you shouldn’t be confused, simply because the term paper writing services present the do my essay papers and there’s no problem to buy custom writing services and be satisfied.
            2010-09-28 17:58 | buy essays cheap

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            Frequently, that is better to buy essays, particularly if you do not have an opportunity to compose even an easy academic task.
            2010-12-10 20:13 | custom essays

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            Excellent post. I was checking continuously this blog and I'm impressed! Very useful information specifically the last part :) I care for such info a lot. I was looking for this certain information for a very long time. Thank you and good luck.
            2013-10-03 07:48 | have a peek here

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            I do not even understand how I stopped up here, but I assumed this publish used to be good. I don't realize who you might be but certainly you're going to a well-known blogger if you aren't already ;) Cheers!
            2013-10-22 17:32 | agen bola

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            I like the valuable info you provide in your articles. I'll bookmark your weblog and check again here frequently. I'm quite certain I'll learn a lot of new stuff right here! Best of luck for the next!
            2013-11-08 10:14 | Navigate Here

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            但沒(méi)理由維護(hù)這個(gè)東西里面的東西。不僅僅是vector,所有的容器如果按你這種思維去用,都會(huì)出問(wèn)題 為復(fù)雜數(shù)據(jù)結(jié)構(gòu)時(shí),則應(yīng)該存儲(chǔ)該數(shù)據(jù)
            2014-09-10 21:40 | Agen Tangkas

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            果按你這種思維去用,都會(huì)出問(wèn)題 為復(fù)雜數(shù)據(jù)結(jié)構(gòu)時(shí),則應(yīng)該

            http://uefa88.net
            2014-09-10 21:42 | Agen Tangkas Terpercaya

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            實(shí)應(yīng)該是你的責(zé)任。的容器如果按你員變量是指針就把指針?biāo)傅牡胤轿鰳?gòu)

            http://www.sidikjaritermurah.com
            2014-09-10 21:44 | Mesin Absensi Sidik Jari

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            一旦數(shù)據(jù)結(jié)構(gòu)為復(fù)雜數(shù)據(jù)結(jié)構(gòu)時(shí),則應(yīng)該存儲(chǔ)該數(shù)據(jù)的指針。

            http://multibet88.org
            2014-10-16 03:22 | judi online

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            http://agent108.org
            2014-10-16 16:16 | judi bola

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            則應(yīng)該存儲(chǔ)該數(shù)據(jù)的指針。

            http://homebet88.com
            2014-10-16 16:18 | agen bola terpercaya

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            都會(huì)出問(wèn)題 為復(fù)雜數(shù) http://citibet88.com
            2014-10-16 16:18 | taruhan bola

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            一旦數(shù)據(jù)結(jié)構(gòu)為復(fù)雜數(shù)據(jù)結(jié)構(gòu)時(shí) http://speedbet88.com
            2014-10-16 16:19 | agen bola

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            但沒(méi)理由維護(hù)這個(gè)東西里面的東西。所有的容器如果按你這種思維去用,則應(yīng)該存儲(chǔ)該數(shù)據(jù) http://www.speedbet88.biz
            2014-10-25 03:24 | agen bola

            # # re: 使用std::vector 的陷阱 回復(fù) 更多評(píng)論   回復(fù)  更多評(píng)論   

            我們的<a代理href="http://agent108.org">朱迪·博拉網(wǎng)</A>最好的,最大的,最可靠的agent108 - 給促銷(xiāo)獎(jiǎng)金10萬(wàn)每存款將獲得5%的獎(jiǎng)金
            存取速度非常快,馬上加入我們的行列。
            2014-10-28 17:30 | milestone

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            但沒(méi)理由維護(hù)這個(gè)東西里面的東西。所有的容器如果按你這種思維去用,則應(yīng)該存儲(chǔ)該數(shù)據(jù) http://www.citibet88.com
            2014-10-29 18:03 | taruhan bola

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            很不錯(cuò)的博客,謝謝分享這個(gè)非常有趣的信息。保持成功
            2014-11-18 22:03 | sbobet online

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            但沒(méi)理由維護(hù)這個(gè)東西里面的東西。所有的容器如果按你這種思維去用,則應(yīng)該存儲(chǔ)該數(shù)據(jù)
            2014-11-20 20:51 | agen bola terpercaya

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            www.on303.com adalah agen judi bola terpercaya di indonesia , dengan customer service yang ramah siap membantu anda semua.
            2015-07-14 13:42 | judi bola

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            この記事では、読者のために非常に良いと便利です。知識(shí)の共有をありがとうございました
            2016-02-18 11:12 | obat penggugur kandungan

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            私のような初心者のための読書(shū)の多くを必要とし、様々なブログ上の情報(bào)を検索します。あなたはとても素?cái)长蚬灿肖贰⑺饯蚬奈瑜贰⒂浭?
            2016-03-18 10:30 | cara menggugurkan kandungan

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            容器只有責(zé)任維護(hù)你給他的東西,但沒(méi)理由維護(hù)這個(gè)東西里面的東西。不僅僅是vector,STL所有的容器如果按你這種思維去用
            2016-04-22 13:26 | Cara Menggugurkan Kandungan

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            如果有引用記數(shù)的話(huà),如智能指針, 就不會(huì)被釋放掉了。不過(guò)如果一般編碼里面不需要用到引用記數(shù)的話(huà),還是方法1比較簡(jiǎn)便
            2016-04-22 13:27 | Obat Penggugur Kandungan

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            Mate this is a very nice blog here. I wanted to comment & say that I enjoyed reading your posts & they are all very well written out. You make blogging look easy lol I’ll attemp to start a blog later today and I hope it’s half as good as your blog! Much success to you!
            2016-06-13 20:18 | Dr.Aborsi Kandungan

            # re: 使用std::vector 的陷阱  回復(fù)  更多評(píng)論   

            I would like to start a pressure group of Australian authors whose purpose is to remind the buyers at Council Libraries that one of their functions is to support and nurture Australian Literature.
            2016-06-16 11:14 | klinik apotik24
            久久综合视频网站| 性欧美丰满熟妇XXXX性久久久 | 波多野结衣久久| 久久婷婷五月综合国产尤物app | 国产精品久久久天天影视香蕉 | 久久综合九色综合97_久久久| 国产精品伦理久久久久久| 久久精品不卡| 亚洲综合伊人久久大杳蕉| 久久99久久无码毛片一区二区| 91麻豆国产精品91久久久| 久久亚洲精品无码AV红樱桃| 国内精品久久久久久麻豆| 亚洲国产精品综合久久一线| 97久久国产亚洲精品超碰热 | 久久精品国产亚洲一区二区| 久久99久国产麻精品66| 国产亚洲美女精品久久久久狼| 九九精品久久久久久噜噜| 久久精品国产一区二区三区日韩| 亚洲欧洲久久久精品| 一本大道久久a久久精品综合| www久久久天天com| 国产亚洲婷婷香蕉久久精品| 久久人做人爽一区二区三区| 久久久免费观成人影院| 91精品国产综合久久婷婷| 久久久久亚洲精品日久生情| 国产99久久九九精品无码| 久久精品亚洲日本波多野结衣| 亚洲AV日韩精品久久久久久久| 激情久久久久久久久久| 久久这里只精品国产99热| av无码久久久久久不卡网站 | 亚洲国产精品成人久久| 欧美精品九九99久久在观看| 久久精品国产一区二区三区不卡| 精品一区二区久久| 久久99精品国产一区二区三区| 久久国产精品99国产精| 亚洲乱码中文字幕久久孕妇黑人|