• <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
            <2009年6月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            友情鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜


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

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

            容器和算法

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

                vector<int> v(3);         //聲明一個包含3個元素的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也包含了很多算法用來操作容器中的數(shù)據(jù)。你可以使一個vetor中的元素逆向排列,舉個使用reverse算法的例子。
               
             reverse(v.begin(), v.end());   // v[0] == 17, v[1] == 10, v[2] == 7

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

            這些事實的原理都是一樣的: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];

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


            下一節(jié)《迭代器》
            posted on 2012-02-20 21:02 canaan 閱讀(486) 評論(0)  編輯 收藏 引用 所屬分類: 外文翻譯
            99久久国产亚洲综合精品| 精品免费tv久久久久久久| 亚洲精品WWW久久久久久| 久久夜色精品国产www| 亚洲人成无码久久电影网站| 午夜天堂精品久久久久| 国产精品丝袜久久久久久不卡| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久久久综合国产欧美一区二区 | 日韩AV毛片精品久久久| 一本色道久久88综合日韩精品| 久久综合狠狠综合久久综合88| 伊人久久精品线影院| 久久亚洲AV成人无码软件| 久久国产乱子伦精品免费强| 久久人人爽人人人人爽AV| 国产69精品久久久久9999| 久久天天躁狠狠躁夜夜avapp | 久久午夜综合久久| 国产99精品久久| 亚洲AV无码久久| 久久久久免费精品国产| 亚洲伊人久久成综合人影院| 久久精品国产精品青草| 91久久婷婷国产综合精品青草| 国产69精品久久久久APP下载| 久久久精品视频免费观看| 国产精品99久久久久久人| 热re99久久6国产精品免费| 国产精品乱码久久久久久软件| 国产精品免费久久久久影院| 一本色道久久88加勒比—综合| 99精品国产在热久久| 国产∨亚洲V天堂无码久久久| 精品久久亚洲中文无码| 久久国产色av免费看| 久久人人爽人人爽人人片AV高清| 狠狠色丁香久久婷婷综合蜜芽五月 | 亚洲乱码中文字幕久久孕妇黑人| 无码国内精品久久人妻麻豆按摩| 久久国产三级无码一区二区|