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

            山寨:不是最好的,是最適合我們的!歡迎體驗(yàn)山寨 中文版MSDN

            Blog @ Blog

            當(dāng)華美的葉片落盡,生命的脈絡(luò)才歷歷可見。 -- 聶魯達(dá)

            常用鏈接

            統(tǒng)計(jì)

            積分與排名

            BBS

            Blog

            Web

            最新評論

            STL迭代器簡介

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

                        input         output
                          \            /
                             forward
                                 |
                            bidirectional
                                 |
                           random access

             

             

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

            各個(gè)迭代器的功能如下:

            迭代器類別

            說明

            輸入

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

            輸出

            向容器中寫入元素。輸出迭代器只能一次一個(gè)元素向前移動(dòng)。輸出迭代器只支持一遍算法,統(tǒng)一輸出迭代器不能兩次遍歷一個(gè)序列

            正向

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

            雙向

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

            隨機(jī)訪問

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

            迭代器的操作:

            每種迭代器均可進(jìn)行包括表中前一種迭代器可進(jìn)行的操作。

            迭代器操作

            說明

            所有迭代器

            p++

            后置自增迭代器

            ++p

            前置自增迭代器

            輸入迭代器

            *p

            復(fù)引用迭代器,作為右值

            p=p1

            將一個(gè)迭代器賦給另一個(gè)迭代器

            p==p1

            比較迭代器的相等性

            p!=p1

            比較迭代器的不等性

            輸出迭代器

            *p

            復(fù)引用迭代器,作為左值

            p=p1

            將一個(gè)迭代器賦給另一個(gè)迭代器

            正向迭代器

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

            雙向迭代器

            --p

            前置自減迭代器

            p--

            后置自減迭代器

            隨機(jī)迭代器

            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的前面或同一位置時(shí)返回true,否則返回false

            p>p1

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

            p>=p1

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

            只有順序容器和關(guān)聯(lián)容器支持迭代器遍歷,各容器支持的迭代器的類別如下:

            容器

            支持的迭代器類別

            vector

            隨機(jī)訪問

            deque

            隨機(jī)訪問

            list

            雙向

            set

            雙向

            multiset

            雙向

            map

            雙向

            multimap

            雙向

            stack

            不支持

            queue

            不支持

            priority_queue

            不支持

             

            posted on 2008-12-01 10:37 isabc 閱讀(1442) 評論(0)  編輯 收藏 引用 所屬分類: STL(容器、算法、迭代器)

            廣告信息(免費(fèi)廣告聯(lián)系)

            中文版MSDN:
            歡迎體驗(yàn)

            四虎国产精品成人免费久久| 欧美日韩精品久久免费| 中文成人久久久久影院免费观看| 国产亚洲美女精品久久久久狼| 亚洲一区精品伊人久久伊人| 国产高清国内精品福利99久久| 国产一级持黄大片99久久| 久久青青草原亚洲av无码app| 色欲综合久久中文字幕网| 99精品久久久久久久婷婷| av色综合久久天堂av色综合在| 久久亚洲国产精品成人AV秋霞| 免费无码国产欧美久久18| 少妇熟女久久综合网色欲| 久久久亚洲AV波多野结衣| 精产国品久久一二三产区区别| 精品一二三区久久aaa片| 精品久久8x国产免费观看| 久久狠狠色狠狠色综合| 亚洲天堂久久精品| 久久亚洲国产成人精品无码区| 久久伊人影视| 久久人人爽人人爽人人AV| 久久r热这里有精品视频| 久久综合色之久久综合| 亚洲国产精品无码久久久不卡| 国内精品久久久久久99蜜桃| 99久久精品无码一区二区毛片| 久久99精品久久久久久齐齐| 久久精品国产亚洲AV久| 国内精品伊人久久久久AV影院| 精品久久久久中文字幕一区| 久久综合久久美利坚合众国| 久久久久亚洲AV无码网站| 欧美粉嫩小泬久久久久久久| 亚洲国产精品久久电影欧美| 久久精品免费一区二区三区| 久久精品中文无码资源站| 狠狠色丁香婷婷综合久久来来去| 99精品国产免费久久久久久下载| 91视频国产91久久久|