• <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>
             name:example2_3.cpp
            // alias:aesthetic version

            #include <iostream>
            #include <vector>
            #include <algorithm>
            #include <iterator>

            using namespace std;

            void main(void)
            {
            typedef vector<int> int_vector;
            typedef istream_iterator<int> istream_itr;
            typedef ostream_iterator<int> ostream_itr;
            typedef back_insert_iterator< int_vector > back_ins_itr;

            // STL中的vector容器
            int_vector num;

            // 從標(biāo)準(zhǔn)輸入設(shè)備讀入整數(shù),
            // 直到輸入的是非整型數(shù)據(jù)為止
            copy(istream_itr(cin), istream_itr(), back_ins_itr(num));

            // STL中的排序算法
            sort(num.begin(), num.end());

            // 將排序結(jié)果輸出到標(biāo)準(zhǔn)輸出設(shè)備
            copy(num.begin(), num.end(), ostream_itr(cout, "\n"));
            }
                

              在這個程序里幾乎每行代碼都是和STL有關(guān)的(除了main和那對花括號,當(dāng)然還有注釋),并且它包含了STL中幾乎所有的各大部件(容器container,迭代器iterator, 算法algorithm, 適配器adaptor),唯一的遺憾是少了函數(shù)對象(functor)的身影。
             前面提到的迭代器可以對容器內(nèi)的任意元素進(jìn)行定位和訪問。在STL里,這種特性被加以推廣了。一個cin代表了來自輸入設(shè)備的一段數(shù)據(jù)流,從概念上講它對數(shù)據(jù)流的訪問功能類似于一般意義上的迭代器,但是C++中的cin在很多地方操作起來并不像是一個迭代器,原因就在于其接口和迭代器的接口不一致(比如:不能對cin進(jìn)行++運算,也不能對之進(jìn)行取值運算--即*運算)。為了解決這個矛盾,就需要引入適配器的概念。istream_iterator便是一個適配器,它將cin進(jìn)行包裝,使之看起來像是一個普通的迭代器,這樣我們就可以將之作為實參傳給一些算法了(比如這里的copy算法)。因為算法只認(rèn)得迭代器,而不會接受cin。對于上面程序中的第一個copy函數(shù)而言,其第一個參數(shù)展開后的形式是:istream_iterator(cin),其第二個參數(shù)展開后的形式是:istream_iterator()(如果你對typedef的語法不清楚,可以參考有關(guān)的c++語言書籍)。其效果是產(chǎn)生兩個迭代器的臨時對象,前一個指向整型輸入數(shù)據(jù)流的開始,后一個則指向"pass-the-end value"。這個函數(shù)的作用就是將整型輸入數(shù)據(jù)流從頭至尾逐一"拷貝"到vector這個準(zhǔn)整型數(shù)組里,第一個迭代器從開始位置每次累進(jìn),最后到達(dá)第二個迭代器所指向的位置?;蛟S你要問,如果那個copy函數(shù)的行為真如我所說的那樣,為什么不寫成如下這個樣子呢?

            copy(istream_iterator<int>(cin), istream_iterator<int>(), num.begin());


              你確實可以這么做,但是有一個小小的麻煩。還記得第一版程序里的那個數(shù)組越界問題嗎?如果你這么寫的話,就會遇到類似的麻煩。原因在于copy函數(shù)在"拷貝"數(shù)據(jù)的時候,如果輸入的數(shù)據(jù)個數(shù)超過了vector容器的范圍時,數(shù)據(jù)將會拷貝到容器的外面。此時,容器不會自動增長容量,因為這只是簡單地拷貝,并不是從末端插入。為了解決這個問題,另一個適配器back_insert_iterator登場了,它的作用就是引導(dǎo)copy算法每次在容器末端插入一個數(shù)據(jù)。程序中的那個back_ins_itr(num)展開后就是:back_insert_iterator(num),其效果是生成一個這樣的迭待器對象。

              終于將講完了三分之一(真不容易?。?,好在第二句和前一版程序沒有差別,這里就略過了。至于第三句,ostream_itr(cout, "\n")展開后的形式是:ostream_iterator(cout, "\n"),其效果是產(chǎn)生一個處理輸出數(shù)據(jù)流的迭待器對象,其位置指向數(shù)據(jù)流的起始處,并且以"\n"作為分割符。第二個copy函數(shù)將會從頭至尾將vector中的內(nèi)容"拷貝"到輸出設(shè)備,第一個參數(shù)所代表的迭代器將會從開始位置每次累進(jìn),最后到達(dá)第二個參數(shù)所代表的迭代器所指向的位置。

              這就是全部的內(nèi)容。

            Posted on 2006-01-01 14:27 艾凡赫 閱讀(394) 評論(0)  編輯 收藏 引用 所屬分類: C++
            久久99久久成人免费播放| 国产精品一区二区久久精品涩爱| 久久久久无码精品国产不卡| 国产一级做a爰片久久毛片| 久久99精品久久久久久野外| 亚洲精品乱码久久久久久自慰| 久久久国产精品亚洲一区| 成人精品一区二区久久| 久久久久久伊人高潮影院| 色综合合久久天天综合绕视看| 欧美午夜A∨大片久久| 激情伊人五月天久久综合| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区| 亚洲午夜无码AV毛片久久| 99国产精品久久| 久久久久久久精品成人热色戒| 一本一道久久精品综合| 九九久久自然熟的香蕉图片| 久久精品国产AV一区二区三区| 国产成人无码精品久久久免费 | 久久综合亚洲色HEZYO社区| 久久亚洲国产中v天仙www| 久久精品国产亚洲AV蜜臀色欲 | 97久久精品人人澡人人爽| 无码超乳爆乳中文字幕久久| 伊人色综合九久久天天蜜桃| 久久高潮一级毛片免费| 99国产精品久久久久久久成人热| 伊人热热久久原色播放www| 精品国产青草久久久久福利| 久久免费看黄a级毛片| 国产精品欧美亚洲韩国日本久久| 人妻少妇久久中文字幕| 综合久久国产九一剧情麻豆| 一本色道久久HEZYO无码| 久久久噜噜噜久久中文字幕色伊伊| 欧美午夜精品久久久久久浪潮| 久久久久亚洲av成人无码电影| 久久精品国产福利国产琪琪 | 日本久久久久久中文字幕| 高清免费久久午夜精品|