• <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>
            隨筆 - 224  文章 - 41  trackbacks - 0
            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            享受編程

            常用鏈接

            留言簿(11)

            隨筆分類(159)

            隨筆檔案(224)

            文章分類(2)

            文章檔案(4)

            經典c++博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            STL迭代器簡介

            原文地址:http://www.shnenglu.com/lmlf001/archive/2006/04/20/5971.aspx

             

             

            標準模板庫(The Standard Template Library, STL)定義了五種迭代器。下面的圖表畫出了這幾種:

             

                  input         output
                             \            /
                              forward
                                    |
                            bidirectional
                                    |
                           random access

             

            要注意,上面這圖表并不是表明它們之間的繼承關系:而只是描述了迭代器的種類和接口。處于圖表下層的迭代器都是相對于處于圖表上層迭代器的擴張集。例如:forward迭代器不但擁有inputoutput迭代器的所有功能,還擁有更多的功能。

             

            各個迭代器的功能如下:

            迭代器類別

            說明

            輸入

            從容器中讀取元素。輸入迭代器只能一次讀入一個元素向前移動,輸入迭代器只支持一遍算法,同一個輸入迭代器不能兩遍遍歷一個序列

            輸出

            向容器中寫入元素。輸出迭代器只能一次一個元素向前移動。輸出迭代器只支持一遍算法,統一輸出迭代器不能兩次遍歷一個序列

            正向

            組合輸入迭代器和輸出迭代器的功能,并保留在容器中的位置

            雙向

            組合正向迭代器和逆向迭代器的功能,支持多遍算法

            隨機訪問

            組合雙向迭代器的功能與直接訪問容器中任何元素的功能,即可向前向后跳過任意個元素

             

            迭代器的操作:

            每種迭代器均可進行包括表中前一種迭代器可進行的操作。

            迭代器操作

            說明

            所有迭代器

            p++

            后置自增迭代器

            ++p

            前置自增迭代器

            輸入迭代器

            *p

            復引用迭代器,作為右值

            p=p1

            將一個迭代器賦給另一個迭代器

            p==p1

            比較迭代器的相等性

            p!=p1

            比較迭代器的不等性

            輸出迭代器

            *p

            復引用迭代器,作為左值

            p=p1

            將一個迭代器賦給另一個迭代器

            正向迭代器

            提供輸入輸出迭代器的所有功能

            雙向迭代器

            --p

            前置自減迭代器

            p--

            后置自減迭代器

            隨機迭代器

            p+=i

            將迭代器遞增i

            p-=i

            將迭代器遞減i

            p+i

            p位加i位后的迭代器

            p-i

            p位減i位后的迭代器

            p[i]

            返回p位元素偏離i位的元素引用

            p<p1

            如果迭代器p的位置在p1前,返回true,否則返回false

            p<=p1

            p的位置在p1的前面或同一位置時返回true,否則返回false

            p>p1

            如果迭代器p的位置在p1后,返回true,否則返回false

            p>=p1

            p的位置在p1的后面或同一位置時返回true,否則返回false

             

            只有順序容器和關聯容器支持迭代器遍歷,各容器支持的迭代器的類別如下:

            容器

            支持的迭代器類別

            vector

            隨機訪問

            deque

            隨機訪問

            list

            雙向

            set

            雙向

            multiset

            雙向

            map

            雙向

            multimap

            雙向

            stack

            不支持

            queue

            不支持

            priority_queue

            不支持

             

            posted on 2008-11-24 12:32 漂漂 閱讀(285) 評論(0)  編輯 收藏 引用 所屬分類: STL
            久久精品国产免费观看三人同眠| 无码任你躁久久久久久老妇App| 婷婷国产天堂久久综合五月| 久久播电影网| 久久久久久久综合综合狠狠| 国内精品伊人久久久影院| 欧美黑人激情性久久| 无码国产69精品久久久久网站| 欧美精品福利视频一区二区三区久久久精品| 国内精品伊人久久久久影院对白| 国产午夜福利精品久久| 狠狠色婷婷久久综合频道日韩 | 91麻豆精品国产91久久久久久| 久久A级毛片免费观看| 精品久久久久香蕉网| 国产精品久久久久久久久鸭| 久久久国产乱子伦精品作者 | 国产精品对白刺激久久久| 国产午夜精品理论片久久影视 | 伊人久久五月天| 日韩精品国产自在久久现线拍| 99久久夜色精品国产网站| 久久久这里只有精品加勒比| 色婷婷久久综合中文久久蜜桃av| 久久99国产精品久久久 | 亚洲国产综合久久天堂| 日韩精品久久久久久久电影蜜臀| 精品久久久久久无码专区不卡 | 一本色综合网久久| 色婷婷综合久久久久中文字幕| 久久精品www人人爽人人| 品成人欧美大片久久国产欧美| 久久婷婷五月综合97色直播| 国产精品99久久久久久猫咪| 久久综合噜噜激激的五月天| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久91精品综合国产首页| 久久亚洲AV成人出白浆无码国产 | 久久婷婷五月综合成人D啪| 99久久精品国产一区二区三区| 国产人久久人人人人爽|