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

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            完全版STL程序學習

            #include? " stdafx.h "
            #ifndef????IOSTREAM_H
            #include?
            < iostream >
            #endif
            #include?
            < vector >
            #include?
            < algorithm >
            #include?
            < iterator >

            using ? namespace ?std;

            int ?_tmain( int ?argc,?_TCHAR * ?argv[]) {
            ????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;

            ????
            // ?從標準輸入設備讀入整數,?
            ????
            // ?直到輸入的是非整型數據為止
            ????copy(istream_itr(cin),?istream_itr(),?back_ins_itr(num));

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

            ????
            // ?將排序結果輸出到標準輸出設備
            ????copy(num.begin(),?num.end(),?ostream_itr(cout,? " \n " ));

            ????
            return ? 0 ;
            }
            完全STL的程序

            在這個程序里幾乎每行代碼都是和STL有關的(除了main和那對花括號,當然還有注釋),并且它包含了STL中幾乎所有的各大部件(容器container,迭代器iterator, 算法algorithm, 適配器adaptor),唯一的遺憾是少了函數對象(functor)的身影。

            還記得開頭提到的一個典型系統所具有的基本特征嗎?--輸入+處理+輸出。所有這些功能,在上面的程序里,僅僅是通過三行語句來實現的,其中每一行語句對應一種操作。對于數據的操作被高度的抽象化了,而算法和容器之間的組合,就像搭積木一樣輕松自如,系統的耦合度被降到了極低點。這就是閃耀著泛型之光的STL的偉大力量。如此簡潔,如此巧妙,如此神奇!就像魔術一般,以至于再一次讓你摸不著頭腦。怎么實現的?為什么在看第二版程序的時候如此清晰的你,又墜入了五里霧中(竊喜)。

            請留意此處的標題(唯美主義的杰作),在實際環境中,你未必要做到這樣完美。畢竟美好愿望的破滅,在生活中時常會發生。過于理想化,并不是一件好事,至少我是這么認為的。正如前面提到的,這個程序只是為了展示STL的獨特魅力,你不得不為它的出色表現所折服,也許只有深諳STL之道的人才會想出這樣的玩意兒來。如果你只是一般性的使用STL,做到第二版這樣的程度也就可以了。

            實在是因為這個程序太過"簡單",以至于我無法肯定,在你還沒有完全掌握STL之前,通過我的講解,是否能夠領會這區區三行代碼,我將盡我的最大努力。

            前面提到的迭代器可以對容器內的任意元素進行定位和訪問。在STL里,這種特性被加以推廣了。一個cin代表了來自輸入設備的一段數據流,從概念上講它對數據流的訪問功能類似于一般意義上的迭代器,但是C++中的cin在很多地方操作起來并不像是一個迭代器,原因就在于其接口和迭代器的接口不一致(比如:不能對cin進行++運算,也不能對之進行取值運算--即*運算)。為了解決這個矛盾,就需要引入適配器的概念。istream_iterator便是一個適配器,它將cin進行包裝,使之看起來像是一個普通的迭代器,這樣我們就可以將之作為實參傳給一些算法了(比如這里的copy算法)。因為算法只認得迭代器,而不會接受cin。對于上面程序中的第一個copy函數而言,其第一個參數展開后的形式是:istream_iterator(cin),其第二個參數展開后的形式是:istream_iterator()(如果你對typedef的語法不清楚,可以參考有關的c++語言書籍)。其效果是產生兩個迭代器的臨時對象,前一個指向整型輸入數據流的開始,后一個則指向"pass-the-end value"。這個函數的作用就是將整型輸入數據流從頭至尾逐一"拷貝"到vector這個準整型數組里,第一個迭代器從開始位置每次累進,最后到達第二個迭代器所指向的位置。或許你要問,如果那個copy函數的行為真如我所說的那樣,為什么不寫成如下這個樣子呢?

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

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

            posted on 2006-04-24 10:04 楊粼波 閱讀(820) 評論(0)  編輯 收藏 引用 所屬分類: 學習筆記

            狠狠久久亚洲欧美专区| 成人综合久久精品色婷婷| 久久精品国产乱子伦| 亚洲成av人片不卡无码久久| 91久久精品无码一区二区毛片| 精品久久久久久无码专区不卡| 奇米综合四色77777久久| 亚洲国产另类久久久精品| 久久久久久精品久久久久| 亚洲va久久久噜噜噜久久狠狠| 亚洲va久久久噜噜噜久久男同| 亚洲国产一成人久久精品| 欧美喷潮久久久XXXXx| 国产婷婷成人久久Av免费高清| 国产精品美女久久久久| 亚洲国产精品热久久| 日本精品一区二区久久久| 思思久久好好热精品国产| 伊人久久大香线焦AV综合影院| 人妻少妇久久中文字幕一区二区 | 一本色道久久综合亚洲精品| 无码人妻精品一区二区三区久久| 国产韩国精品一区二区三区久久| 国产高清美女一级a毛片久久w| 亚洲AⅤ优女AV综合久久久| 亚洲精品乱码久久久久久中文字幕| 国产精品福利一区二区久久| 精品无码久久久久久久动漫| 久久久艹| 亚洲精品tv久久久久久久久| 大香网伊人久久综合网2020| 久久久久久久97| 国产福利电影一区二区三区久久老子无码午夜伦不 | 国色天香久久久久久久小说| 精品久久久久久| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久久久久亚洲精品不卡 | 麻豆亚洲AV永久无码精品久久| 久久久国产精品网站| 思思久久99热只有频精品66| www.久久热.com|