• <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)以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            完全版STL程序?qū)W習(xí)

            #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;

            ????
            // ?從標(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 " ));

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

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

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

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

            實(shí)在是因?yàn)檫@個(gè)程序太過(guò)"簡(jiǎn)單",以至于我無(wú)法肯定,在你還沒(méi)有完全掌握STL之前,通過(guò)我的講解,是否能夠領(lǐng)會(huì)這區(qū)區(qū)三行代碼,我將盡我的最大努力。

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

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

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

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

            亚洲人成电影网站久久| 久久强奷乱码老熟女网站| 精品久久久久久久中文字幕 | 婷婷久久久亚洲欧洲日产国码AV| 欧美精品丝袜久久久中文字幕 | 四虎影视久久久免费| 日韩精品久久久肉伦网站| 91精品国产色综合久久| 久久99精品国产麻豆蜜芽| 久久久亚洲AV波多野结衣| 久久99国产精品久久99| 99久久国产综合精品五月天喷水| 777午夜精品久久av蜜臀| 国产成人精品久久亚洲| 国产精品久久久久久久人人看| 国产精品久久久久影院色| 亚洲欧洲精品成人久久奇米网| 亚洲嫩草影院久久精品| 亚洲AV日韩精品久久久久久久| 久久av免费天堂小草播放| 久久精品国产影库免费看 | 亚洲а∨天堂久久精品| 亚洲成色999久久网站| 久久综合88熟人妻| 亚洲女久久久噜噜噜熟女| 日韩欧美亚洲国产精品字幕久久久| 国产美女久久久| 久久精品亚洲精品国产色婷| 久久综合九色综合网站| 色综合久久天天综线观看| 久久夜色精品国产| 99久久无码一区人妻| 国产99久久九九精品无码| 欧美激情精品久久久久| 日本精品久久久久中文字幕8| AV无码久久久久不卡蜜桃| 久久er99热精品一区二区| 久久青青草原精品国产| 亚洲精品国产美女久久久| 久久人人爽人人爽人人片AV麻烦 | 久久人人爽人人爽人人片AV高清 |