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

            Zero Lee的專欄

            關(guān)于vector的使用

            Item1: vector的使用
            JG問(wèn)題
            void f(vector<int>& v) {
            ???v[0] = 1;???// A
            ?? v[1] = 2;???// B
            }
            GURU問(wèn)題:

            ?1 vector < int > ?v;
            ?2 v.reserve( 2
            );
            ?3 assert(v.capacity()? == ? 2
            );
            ?4 v[ 0 ]? = ? 1
            ;
            ?5 v[ 1 ]? = ? 2
            ;
            ?6 for ?(vector < int > ::iterator?i? =
            ?v.begin();?
            ?7 ???????i? < ?v.end();?i ++ )?
            {
            ?8 ????cout? << ? * i? <<
            ?endl;
            ?9 }

            10 cout? << ?v[ 0 ];
            11 v.reserve( 100
            );
            12 assert(v.capacity()? == ? 100
            );
            13 cout? << ?v[ 0
            ];
            14 v[ 2 ]? = ?? 3
            ;
            15 v[ 3 ]? = ? 4
            ;
            16 // ?...

            17 v[ 99 ]? = ? 100 ;
            18 for ?(vector < int > ::iterator?i? =
            ?v.begin();
            19 ???????i? < ?v.end();?i ++ )?
            {
            20 ????cout? << ? * i? <<
            ?endl;
            21 }
            對(duì)于以上兩個(gè)問(wèn)題,可能存在如下的建議:
            1) JG問(wèn)題中B與A的區(qū)別
            ?? 如果V非空,則A與B無(wú)任何區(qū)別,如果V為空,則B行將一定會(huì)拋出一個(gè)std::out_of_range異常,至于A的行為,標(biāo)準(zhǔn)并未加任何說(shuō)明。
            ?? 原因在于:at()成員函數(shù)會(huì)對(duì)其進(jìn)行越界檢查,而operator[]操作符則不會(huì),秉承于數(shù)組[]下標(biāo)運(yùn)算符也不會(huì)檢查越界一樣。

            2) GURU問(wèn)題
            代碼:
            1 vector < int > ?v;
            2 v.reserve( 2
            );
            3 assert(v.capacity()? == ? 2
            );
            4
            ?1> 斷言可能會(huì)失敗。reserve()函數(shù)的調(diào)用會(huì)保證v的容量至少為2,也可能大于2,而且容量是呈指數(shù)速度上升的。應(yīng)該改為assert(v.capacity() >= 2);
            ?2> 但是改進(jìn)后的斷言顯的有點(diǎn)多余。因?yàn)闃?biāo)準(zhǔn)已保證斷言的內(nèi)容,寫(xiě)上只會(huì)帶來(lái)不必要的混亂,除非不相信標(biāo)準(zhǔn)。
            代碼:
            1 v[ 0 ]? = ? 1 ;
            2 v[ 1 ]? = ? 2
            ;
            3
            ? size ——>resize, capacity ——> reserve
            1> size告訴你容器中目前實(shí)際有多少元素,而對(duì)應(yīng)的resize會(huì)在容器的尾部添加或刪除一些元素,來(lái)調(diào)整容器當(dāng)中的實(shí)際內(nèi)容,使容器達(dá)到指定大小。對(duì)list、deque和vector適用,其他容器則不適用;
            2> capacity則告訴你最少添加多少元素才會(huì)導(dǎo)致容器重分配內(nèi)存。而reserve在必要時(shí)總是使容器的內(nèi)存緩沖區(qū)擴(kuò)至一個(gè)更大的容量。僅對(duì)vector有用。
            3> 但我們實(shí)際上并未向v中添加任何元素,v仍然為空!我們只能使用at()或[]去改變那些確實(shí)存在于容器中的元素,與容器大小息息相關(guān)的。
            因此v[0] = 1; v[1] = 2;在某些情況下會(huì)“順利”執(zhí)行,建議最好不要如此使用,可以使用resize()函數(shù)來(lái)替代reserve()函數(shù)。

            代碼:
            1 for ?(vector < int > ::iterator?i? = ?v.begin();?
            2 ???????i? < ?v.end();?i ++ )?
            {
            3 ????cout? << ? * i? <<
            ?endl;
            4 }

            5

            以上代碼有諸如以下的建議:
            1> 盡量使用const.未修改v中的內(nèi)容,可使用const_iterator;
            2> 盡量使用!=而不用<來(lái)比較迭代器。 != 對(duì)任何迭代器都有效,而< 只對(duì)隨機(jī)訪問(wèn)迭代器有效。list不支持<;
            3> 盡量使用++前綴,而非后綴。可以從++前后綴的實(shí)現(xiàn)代碼中得知,除非一些特殊場(chǎng)合;
            4> 避免無(wú)謂的重復(fù)求值。v.end()函數(shù)在重復(fù)求值,而整個(gè)循環(huán)期間都未改變。除非end()被編譯器進(jìn)行內(nèi)聯(lián),無(wú)調(diào)用開(kāi)銷,最好是將其提到循環(huán)外面;
            5> 盡量使用'\n'而非endl。原因在于endl會(huì)迫使輸出流刷新其內(nèi)部緩沖區(qū),可以在整個(gè)循環(huán)之后寫(xiě)一個(gè)刷新語(yǔ)句。
            6> 盡量使用標(biāo)準(zhǔn)庫(kù)中算法. 如copy()、for_each()。例如這里就可以這樣寫(xiě):
            copy(v.begin(), v.end(), ostream_iterator<int>(cout, '\n'));
            這樣一來(lái)也避免了1>?~ 5的麻煩。

            // zero

            posted on 2006-10-14 15:05 Zero Lee 閱讀(3241) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C++ Performance

            久久精品国产亚洲AV高清热 | AV色综合久久天堂AV色综合在| 精品一久久香蕉国产线看播放 | 99久久99久久久精品齐齐 | 久久亚洲AV无码精品色午夜 | 一级做a爰片久久毛片人呢| 精品国产VA久久久久久久冰| 无码国内精品久久人妻蜜桃| 亚洲精品国产字幕久久不卡| 国产亚洲精品久久久久秋霞| 久久综合久久自在自线精品自| 婷婷久久久亚洲欧洲日产国码AV| 久久久久久久97| 国产欧美久久久精品| 久久91这里精品国产2020| 久久夜色撩人精品国产| 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产成人精品三上悠亚久久| 色婷婷久久综合中文久久蜜桃av| 欧洲精品久久久av无码电影 | 久久天天躁狠狠躁夜夜avapp| 97久久精品国产精品青草| 国产日韩欧美久久| 亚洲精品乱码久久久久久蜜桃| 久久噜噜久久久精品66| 亚洲国产精品18久久久久久| 99久久精品国产麻豆| 精品无码久久久久久久久久| 久久99这里只有精品国产| 国产精品禁18久久久夂久| 欧美精品福利视频一区二区三区久久久精品 | 69久久精品无码一区二区| 久久AAAA片一区二区| 久久影院综合精品| 久久亚洲精品无码观看不卡| 久久久久高潮毛片免费全部播放| 国产午夜精品久久久久九九电影| 日韩AV无码久久一区二区| 国产精品免费久久久久影院| 亚洲AV日韩AV天堂久久| 久久这里有精品视频|