• <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>
            隨筆 - 46  文章 - 39  trackbacks - 0
            <2012年2月>
            2930311234
            567891011
            12131415161718
            19202122232425
            26272829123
            45678910

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            友情鏈接

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜


            標(biāo)準(zhǔn)模板庫(kù)(STL)簡(jiǎn)介

            STL是一個(gè)包含類,算法和迭代器的C++庫(kù);它提供許多計(jì)算機(jī)科學(xué)的基本算法和數(shù)據(jù)結(jié)構(gòu)。STL是一個(gè)基本庫(kù),意味著它的組成有大量的參數(shù):基本上每個(gè)組成部分都是一個(gè)模板。在你使用STL之前要弄清楚模板是怎么工作的。

            容器和算法

            就像許多其他類庫(kù)一樣,STL庫(kù)也包含容器類:這些類的意圖是用來(lái)容納其他對(duì)象。STL包含Vector(矢量,向量)類,list(清單),deque(隊(duì)列),set(集),multiset(多重集),map,multimap,hash_set(哈希集),hash_multiset(哈希多重集),hash_map和hash_multimap。所有這些類都是一個(gè)模板,它可以實(shí)例化來(lái)容納任何類型的對(duì)象。舉個(gè)例子,你可以用vector<int>來(lái)代替普通的C數(shù)組,而且vector不用管理分配動(dòng)態(tài)內(nèi)存。

                vector<int> v(3);         //聲明一個(gè)包含3個(gè)元素的vector。
                v[0] = 7;
                v[1] = v[0] + 3;
                v[2] = v[0] + v[1];       //v[0] == 7, v[1] == 10, v[2] == 17

            STL也包含了很多算法用來(lái)操作容器中的數(shù)據(jù)。你可以使一個(gè)vetor中的元素逆向排列,舉個(gè)使用reverse算法的例子。
               
             reverse(v.begin(), v.end());   // v[0] == 17, v[1] == 10, v[2] == 7

            調(diào)用這個(gè)reverse函數(shù)需要注意兩個(gè)要點(diǎn)。第一,它不是成員函數(shù),而是一個(gè)全局函數(shù)。第二,它需要兩個(gè)參數(shù)而不是一個(gè):它不是作用在容器上,而是作用在一系列元素上。在這個(gè)具體的例子一系列元素就是整個(gè)容器v。

            這些事實(shí)的原理都是一樣的:reverse,像其他STL算法,都是與STL容器類分離的。這意味著reverse不僅僅只能用在vector中的元素,還可以用在lists中的元素,甚至是C數(shù)組中的元素。下面的程序是正確的。
             
              double A[6] = {1.2, 1.3, 1.4, 1.5, 1.6, 1.7};
               reverse(A, A + 6);
               for(int i=0; i<6; ++i)
                 cout << "A[" << i << "]=" << A[i];

            這個(gè)例子用了一個(gè)范圍,就像逆序一個(gè)vector的例子:reverse的第一個(gè)參數(shù)指向這個(gè)范圍的開始,第二個(gè)參數(shù)指向這個(gè)范圍的末尾的后面。這個(gè)范圍是[A, A+6);這兩個(gè)不對(duì)稱的記號(hào)讓人想到兩個(gè)不一樣的端點(diǎn),第一個(gè)是這個(gè)范圍的開始,第二個(gè)是這個(gè)范圍末端的后一位。


            下一節(jié)《迭代器》
            posted on 2012-02-20 21:02 canaan 閱讀(471) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 外文翻譯
            香港aa三级久久三级| 成人精品一区二区久久| 久久久久久亚洲精品不卡 | 久久精品亚洲AV久久久无码| 性高朝久久久久久久久久| 久久这里只有精品18| 久久99精品久久久久久不卡| 久久久久久午夜成人影院 | 久久久久AV综合网成人| 97久久综合精品久久久综合| 人人狠狠综合88综合久久| 国产精品久久久久蜜芽| 狠狠色丁香婷婷综合久久来来去 | 少妇久久久久久久久久| 女同久久| 免费一级欧美大片久久网| 久久亚洲精精品中文字幕| 久久久久九国产精品| 99久久无色码中文字幕| 波多野结衣AV无码久久一区| 伊人久久综合成人网| 国产激情久久久久影院老熟女免费| 久久久精品人妻一区二区三区蜜桃| 久久亚洲国产中v天仙www| 久久免费高清视频| 久久亚洲sm情趣捆绑调教| 久久精品国产精品亚洲下载 | 无码AV波多野结衣久久| 青青草原综合久久大伊人| 欧美大战日韩91综合一区婷婷久久青草 | 四虎国产精品成人免费久久| 久久久久国产一区二区三区| 国产精品嫩草影院久久| 青青青青久久精品国产 | 久久99亚洲网美利坚合众国| 一本久道久久综合狠狠爱| 香蕉99久久国产综合精品宅男自 | 久久久精品国产亚洲成人满18免费网站 | 欧美亚洲另类久久综合| 亚洲国产成人久久综合一| 国产精品成人99久久久久|