• <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>
            posts - 131, comments - 12, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            1
            程序段:
            1
            2
            3
            4
            5
            6
            7
            vector <int> vecInt;
            for (int i=0;i<500;i++)
            {
                vecInt.push_back(i);
            }
            int j= vecInt.capacity();  //j=512
            i = vecInt.size(); //i=500
            1
              

            辦法1 : 使用 clear ,清空元素,但不回收空間.

            1
            2
            3
            vecInt.clear();
            j= vecInt.capacity();  //j=512
            i = vecInt.size();     //i=0
            1
              

            方法2 : 使用 erase循環(huán)刪除,結(jié)果同上.

            1
            2
            3
            4
            5
            6
            7
            vector <int>::iterator iter=vecInt.begin();
            for ( ;iter!=vecInt.end();)
            {
                iter=vecInt.erase(iter);
            }
            j= vecInt.capacity();  //j=512
            i = vecInt.size();     //i=0

            erase在每次操作時,迭代器指針會整體前移1,就是每次都會“搬”全部數(shù)據(jù),所以vector不適合做頻繁刪除的容器.


            方法3 :  使用clear和swap.

                先使用vecInt.clear()清空, 再使用swap,釋放空間回收內(nèi)存.

            (先vec.clear()再vec->swap( (std::vector <temp>)(vec) ),就能實現(xiàn)清空vector和釋放原來vector的內(nèi)存)

            1
            2
            3
            4
            vector <int>().swap(vecInt);    //清除容器并最小化它的容量,
            // vecInt.swap(vector<int>()) ; //另一種寫法
            j= vecInt.capacity();           //j=0
            i = vecInt.size();              //i=0

            該語句是由vector <int>(vecInt).swap(vecInt)的變體而來.

            以下解釋引自CSDN:
            std::vector<T>(v).swap(v);的作用相當(dāng)于: 

            std::vector<T> temp(v);  //1   產(chǎn)生一個和v內(nèi)容一模一樣的vector,只不過temp的容量是恰好滿足其大小 
            temp.swap(v);                 //2  把v和temp交換

            第一句產(chǎn)生一個和v內(nèi)容一模一樣的vector,只不過temp的容量是恰好滿足其大小的 
            第二句把v和temp交換 
            然后temp就自動解析掉了 
            這樣寫的作用是:把v的容量縮小到最佳值
            該例中執(zhí)行這句時,capacity收縮到500,若要收縮到0,需要先clear數(shù)據(jù),再swap.
            ××××××××××××××××××××××
            不過以上還是調(diào)用stl的函數(shù)看到的,不知其內(nèi)部是如何做的。在網(wǎng)上看到其他人的討論有這樣:
            @@而Cygwin中的GCC用的應(yīng)該是HP STL或從它繼承來的SGI STL,對于小內(nèi)存有一種緩沖池機制,一旦進池的內(nèi)存就再也不會交還給系統(tǒng)了
            @@swap 不起作用, 因為原因是 allocator.
            from:http://blog.csdn.net/metalkittie/archive/2008/10/21/3115750.aspx

            注意 clear 不會自動調(diào)用 vector中的成員的析構(gòu)函數(shù),指針數(shù)據(jù)的內(nèi)存需要自己來釋放。


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            日韩人妻无码一区二区三区久久99| 77777亚洲午夜久久多喷| 青青青伊人色综合久久| 一级做a爱片久久毛片| 日韩电影久久久被窝网| 99热成人精品热久久669| 无码任你躁久久久久久| 99久久成人国产精品免费| 日本欧美国产精品第一页久久| 中文字幕乱码人妻无码久久| 久久婷婷久久一区二区三区| 久久久久久精品免费看SSS| 婷婷综合久久狠狠色99h| 久久久午夜精品福利内容| 国产毛片久久久久久国产毛片| 99精品久久精品一区二区| 久久er国产精品免费观看8| 无码人妻精品一区二区三区久久 | 久久精品一本到99热免费| 久久免费精品视频| 国产综合久久久久久鬼色| 国产精品久久久久久久app| 久久久久亚洲精品男人的天堂 | 亚洲国产精品无码久久SM| 久久性精品| 国产精品免费久久久久影院 | 人妻精品久久久久中文字幕| 色综合久久中文色婷婷| 精品国产福利久久久| 狠色狠色狠狠色综合久久| 99精品国产在热久久无毒不卡| 伊人久久大香线蕉av一区| 欧美日韩精品久久免费| 一级做a爰片久久毛片看看| 欧美激情精品久久久久久| 精品久久久久久无码中文野结衣| 久久精品国产亚洲欧美| 国产三级观看久久| 久久久久久久亚洲精品| 一本久久精品一区二区| 99精品国产综合久久久久五月天|