精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

詳細(xì)介紹C++ STL編程(一)

開發(fā) 后端
本文介紹的是C++中的STL編程,希望對(duì)你有幫助,一起來(lái)看。

作為C++標(biāo)準(zhǔn)不可缺少的一部分,STL應(yīng)該是滲透在C++程序的角角落落里的。STL不是實(shí)驗(yàn)室里的寵兒,也不是程序員桌上的擺設(shè),她的激動(dòng)人心并非曇花一現(xiàn)。本教程旨在傳播和普及STL的基礎(chǔ)知識(shí),若能借此機(jī)會(huì)為STL的推廣做些力所能及的事情,到也是件讓人愉快的事情。

1 初識(shí)STL:解答一些疑問

1.1 一個(gè)最關(guān)心的問題:什么是STL

"什么是STL?",假如你對(duì)STL還知之甚少,那么我想,你一定很想知道這個(gè)問題的答案,坦率地講,要指望用短短數(shù)言將這個(gè)問題闡述清楚,也決非易事。因此,如果你在看完本節(jié)之后還是覺得似懂非懂,大可不必著急,在閱讀了后續(xù)內(nèi)容之后,相信你對(duì)STL的認(rèn)識(shí),將會(huì)愈加清晰、準(zhǔn)確和完整。不過(guò),上述這番話聽起來(lái)是否有點(diǎn)像是在為自己糟糕的表達(dá)能力開脫罪責(zé)呢?:)

不知道你是否有過(guò)這樣的經(jīng)歷。在你準(zhǔn)備著手完成數(shù)據(jù)結(jié)構(gòu)老師所布置的家庭作業(yè)時(shí),或者在你為你所負(fù)責(zé)的某個(gè)軟件項(xiàng)目中添加一項(xiàng)新功能時(shí),你發(fā)現(xiàn)需要用到一個(gè)鏈表(List)或者是映射表(Map)之類的東西,但是手頭并沒有現(xiàn)成的代碼。于是在你開始正式考慮程序功能之前,手工實(shí)現(xiàn)List或者M(jìn)ap是不可避免的。

于是……,最終你順利完成了任務(wù)。或許此時(shí),作為一個(gè)具有較高素養(yǎng)的程序員的你還不肯罷休(或者是一個(gè)喜歡偷懶的優(yōu)等生:),因?yàn)槟銜?huì)想到,如果以后還遇到這樣的情況怎么辦?沒有必要再做一遍同樣的事情吧!

如果說(shuō)上述這種情形每天都在發(fā)生,或許有點(diǎn)夸張。但是,如果說(shuō)整個(gè)軟件領(lǐng)域里,數(shù)十年來(lái)確實(shí)都在為了一個(gè)目標(biāo)而奮斗--可復(fù)用性(reusability),這看起來(lái)似乎并不夸張。從最早的面向過(guò)程的函數(shù)庫(kù),到面向?qū)ο蟮某绦蛟O(shè)計(jì)思想,到各種組件技術(shù)(如:COM、EJB),到設(shè)計(jì)模式(design pattern)等等。而STL也在做著類似的事情,同時(shí)在它背后蘊(yùn)涵著一種新的程序設(shè)計(jì)思想--泛型化設(shè)計(jì)(generic programming)。

繼續(xù)上面提到的那個(gè)例子,假如你把List或者map完好的保留了下來(lái),正在暗自得意。且慢,如果下一回的List里放的不是浮點(diǎn)數(shù)而是整數(shù)呢?如果你所實(shí)現(xiàn)的Map在效率上總是令你不太滿意并且有時(shí)還會(huì)出些bug呢?你該如何面對(duì)這些問題?使用STL是一個(gè)不錯(cuò)的選擇,確實(shí)如此,STL可以漂亮地解決上面提到的這些問題,盡管你還可以尋求其他方法。

說(shuō)了半天,到底STL是什么東西呢?

STL(Standard Template Library),即標(biāo)準(zhǔn)模板庫(kù),是一個(gè)具有工業(yè)強(qiáng)度的,高效的C++程序庫(kù)。它被容納于C++標(biāo)準(zhǔn)程序庫(kù)(C++ Standard Library)中,是ANSI/ISO C++標(biāo)準(zhǔn)中***的也是***革命性的一部分。該庫(kù)包含了諸多在計(jì)算機(jī)科學(xué)領(lǐng)域里所常用的基本數(shù)據(jù)結(jié)構(gòu)和基本算法。為廣大C++程序員們提供了一個(gè)可擴(kuò)展的應(yīng)用框架,高度體現(xiàn)了軟件的可復(fù)用性。這種現(xiàn)象有些類似于Microsoft Visual C++中的MFC(Microsoft Foundation Class Library),或者是Borland C++ Builder中的VCL(Visual Component Library),對(duì)于此二者,大家一定不會(huì)陌生吧。

從邏輯層次來(lái)看,在STL中體現(xiàn)了泛型化程序設(shè)計(jì)的思想(generic programming),引入了諸多新的名詞,比如像需求(requirements),概念(concept),模型(model),容器(container),算法(algorithmn),迭代子(iterator)等。與OOP(object-oriented programming)中的多態(tài)(polymorphism)一樣,泛型也是一種軟件的復(fù)用技術(shù)。

從實(shí)現(xiàn)層次看,整個(gè)STL是以一種類型參數(shù)化(type parameterized)的方式實(shí)現(xiàn)的,這種方式基于一個(gè)在早先C++標(biāo)準(zhǔn)中沒有出現(xiàn)的語(yǔ)言特性--模板(template)。如果查閱任何一個(gè)版本的STL源代碼,你就會(huì)發(fā)現(xiàn),模板作為構(gòu)成整個(gè)STL的基石是一件千真萬(wàn)確的事情。除此之外,還有許多C++的新特性為STL的實(shí)現(xiàn)提供了方便。

不知你對(duì)這里一下子冒出這么多術(shù)語(yǔ)做何感想,希望不會(huì)另你不愉快。假如你對(duì)它們之中的大多數(shù)不甚了解,敬請(qǐng)放心,在后續(xù)內(nèi)容中將會(huì)對(duì)這些名詞逐一論述。正如開頭所提到的。

有趣的是,對(duì)于STL還有另外一種解釋--STepanov & Lee,前者是指Alexander Stepanov,STL的創(chuàng)始人;而后者是Meng Lee,她也是使STL得以推行的功臣,***個(gè)STL成品就是他們合作完成的。這一提法源自1995年3月,Dr.Dobb's Journal特約記者, 著名技術(shù)書籍作家Al Stevens對(duì)Alexander Stepanov的一篇專訪。

1.2 追根溯源:STL的歷史

在結(jié)識(shí)新朋友的時(shí)候,大多數(shù)人總是忍不住想了解對(duì)方的過(guò)去。本節(jié)將帶您簡(jiǎn)單回顧一下STL的過(guò)去。

被譽(yù)為STL之父的Alexander Stepanov,出生于蘇聯(lián)莫斯科,早在20世紀(jì)70年代后半期,他便已經(jīng)開始考慮,在保證效率的前提下,將算法從諸多具體應(yīng)用之中抽象出來(lái)的可能性,這便是后來(lái)泛型化思想的雛形。為了驗(yàn)證自己的思想,他和紐約州立大學(xué)教授Deepak Kapur,倫塞里爾技術(shù)學(xué)院教授David Musser共同開發(fā)了一種叫做Tecton的語(yǔ)言。盡管這次嘗試最終沒有取得實(shí)用性的成果,但卻給了Stepanov很大的啟示。

在隨后的幾年中,他又和David Musser等人先后用Schema語(yǔ)言(一種Lisp語(yǔ)言的變種)和Ada語(yǔ)言建立了一些大型程序庫(kù)。這其間,Alexander Stepanov開始意識(shí)到,在當(dāng)時(shí)的面向?qū)ο蟪绦蛟O(shè)計(jì)思想中所存在的一些問題,比如抽象數(shù)據(jù)類型概念所存在的缺陷。Stepanov希望通過(guò)對(duì)軟件領(lǐng)域中各組成部分的分類,逐漸形成一種軟件設(shè)計(jì)的概念性框架。

1987年左右,在貝爾實(shí)驗(yàn)室工作的Alexander Stepanov開始***采用C++語(yǔ)言進(jìn)行泛型軟件庫(kù)的研究。但遺憾的是,當(dāng)時(shí)的C++語(yǔ)言還沒有引入模板(template)的語(yǔ)法,現(xiàn)在我們可以清楚的看到,模板概念之于STL實(shí)現(xiàn),是何等重要。是時(shí)使然,采用繼承機(jī)制是別無(wú)選擇的。盡管如此,Stepanov還是開發(fā)出了一個(gè)龐大的算法庫(kù)。

與此同時(shí),在與Andrew Koenig(前ISO C++標(biāo)準(zhǔn)化委員會(huì)主席)和Bjarne Stroustrup(C++語(yǔ)言的創(chuàng)始人)等***大師們的共事過(guò)程中,Stepanov開始注意到C/C++語(yǔ)言在實(shí)現(xiàn)其泛型思想方面所具有的潛在優(yōu)勢(shì)。就拿C/C++中的指針而言,它的靈活與高效運(yùn)用,使后來(lái)的STL在實(shí)現(xiàn)泛型化的同時(shí)更是保持了高效率。另外,在STL中占據(jù)極其重要地位的迭代子概念便是源自于C/C++中原生指針( native pointer)的抽象。

1988年,Alexander Stepanov開始進(jìn)入惠普的Palo Alto實(shí)驗(yàn)室工作,在隨后的4年中,他從事的是有關(guān)磁盤驅(qū)動(dòng)器方面的工作。直到1992年,由于參加并主持了實(shí)驗(yàn)室主任Bill Worley所建立的一個(gè)有關(guān)算法的研究項(xiàng)目,才使他重新回到了泛型化算法的研究工作上來(lái)。

項(xiàng)目自建立之后,參與者從最初的8人逐漸減少,***只剩下兩個(gè)人--Stepanove本人和Meng Lee。經(jīng)過(guò)長(zhǎng)時(shí)間的努力,最終,信念與汗水所換來(lái)的是一個(gè)包含有大量數(shù)據(jù)結(jié)構(gòu)和算法部件的龐大運(yùn)行庫(kù)。這便是現(xiàn)在的STL的雛形(同時(shí)也是STL的一個(gè)實(shí)現(xiàn)版本--HP STL)。

1993年,當(dāng)時(shí)在貝爾實(shí)驗(yàn)室的Andrew Koenig看到了Stepanove的研究成果,很是興奮。在他的鼓勵(lì)與幫助下,Stepanove于是年9月的圣何塞為ANSI/ISO C++標(biāo)準(zhǔn)委員會(huì)做了一個(gè)相關(guān)演講(題為"The Science of C++ Programming"),向委員們講述了其觀念。然后又于次年3月,在圣迭戈會(huì)議上,向委員會(huì)提交了一份建議書,以期使STL成為C++標(biāo)準(zhǔn)庫(kù)的一部分。盡管這一建議十分龐大,以至于降低了被通過(guò)的可能性,但由于其所包含的新思想,投票結(jié)果以壓倒多數(shù)的意見認(rèn)為推遲對(duì)該建議的決定。

隨后,在眾人的幫助之下,包括Bjarne Stroustrup在內(nèi),Stepanove又對(duì)STL進(jìn)行了改進(jìn)。同時(shí)加入了一個(gè)封裝內(nèi)存模式信息的抽象模塊,也就是現(xiàn)在STL中的allocator,它使STL的大部分實(shí)現(xiàn)都可以獨(dú)立于具體的內(nèi)存模式,從而獨(dú)立于具體平臺(tái)。在同年夏季的滑鐵盧會(huì)議上,委員們以80%贊成,20%反對(duì),最終通過(guò)了提案,決定將STL正式納入C++標(biāo)準(zhǔn)化進(jìn)程之中,隨后STL便被放進(jìn)了會(huì)議的工作文件中。自此,STL終于成為了C++家族中的重要一員。

此后,隨著C++標(biāo)準(zhǔn)的不斷改進(jìn),STL也在不斷地作著相應(yīng)的演化。直至1998年,ANSI/ISO C++標(biāo)準(zhǔn)正式定案,STL始終是C++標(biāo)準(zhǔn)中不可或缺的一大部件。

1.3 千絲萬(wàn)縷的聯(lián)系

在你了解了STL的過(guò)去之后,一些名詞開始不斷在你的大腦中浮現(xiàn),STL、C++、C++標(biāo)準(zhǔn)函數(shù)庫(kù)、泛型程序設(shè)計(jì)、面向?qū)ο蟪绦蛟O(shè)計(jì)……,這些概念意味著什么?他們之間的關(guān)系又是什么?如果你想了解某些細(xì)節(jié),這里也許有你希望得到的答案。

1.3.1 STL和C++

沒有C++語(yǔ)言就沒有STL,這么說(shuō)毫不為過(guò)。一般而言,STL作為一個(gè)泛型化的數(shù)據(jù)結(jié)構(gòu)和算法庫(kù),并不牽涉具體語(yǔ)言(當(dāng)然,在C++里,它被稱為STL)。也就是說(shuō),如果條件允許,用其他語(yǔ)言也可以實(shí)現(xiàn)之。這里所說(shuō)的條件,主要是指類似于"模板"這樣的語(yǔ)法機(jī)制。如果你沒有略過(guò)前一節(jié)內(nèi)容的話,應(yīng)該可以看到,Alexander Stepanov在選擇C++語(yǔ)言作為實(shí)現(xiàn)工具之前,早以采用過(guò)多種程序設(shè)計(jì)語(yǔ)言。

但是,為什么最終還是C++幸運(yùn)的承擔(dān)了這個(gè)歷史性任務(wù)呢?原因不僅在于前述那個(gè)條件,還在于C++在某些方面所表現(xiàn)出來(lái)的優(yōu)越特性,比如:高效而靈活的指針。但是如果把C++作為一種OOP(Object-Oriented Programming,面向?qū)ο蟪绦蛟O(shè)計(jì))語(yǔ)言來(lái)看待的話(事實(shí)上我們一般都是這么認(rèn)為的,不是嗎?),其功能強(qiáng)大的繼承機(jī)制卻沒有給STL的實(shí)現(xiàn)幫上多大的忙。在STL的源代碼里,并沒有太多太復(fù)雜的繼承關(guān)系。

繼承的思想,甚而面向?qū)ο蟮乃枷耄€不足以實(shí)現(xiàn)類似STL這樣的泛型庫(kù)。C++只有在引入了"模板"之后,才直接導(dǎo)致了STL的誕生。這也正是為什么,用其他比C++更純的面向?qū)ο笳Z(yǔ)言無(wú)法實(shí)現(xiàn)泛型思想的一個(gè)重要原因。當(dāng)然,事情總是在變化之中,像Java在這方面,就是一個(gè)很好的例子,jdk1.4中已經(jīng)加入了泛型的特性。

此外,STL對(duì)于C++的發(fā)展,尤其是模板機(jī)制,也起到了促進(jìn)作用。比如:模板函數(shù)的偏特化(template function partial specialization),它被用于在特定應(yīng)用場(chǎng)合,為一般模板函數(shù)提供一系列特殊化版本。這一特性是繼STL被ANSI/ISO C++標(biāo)準(zhǔn)委員會(huì)通過(guò)之后,在Bjarne和Stepanov共同商討之下并由Bjarne向委員會(huì)提出建議的,最終該項(xiàng)建議被通過(guò)。這使得STL中的一些算法在處理特殊情形時(shí)可以選擇非一般化的方式,從而保證了執(zhí)行的效率。

1.3.2 STL和C++標(biāo)準(zhǔn)函數(shù)庫(kù)

STL是***的C++標(biāo)準(zhǔn)函數(shù)庫(kù)中的一個(gè)子集,這個(gè)龐大的子集占據(jù)了整個(gè)庫(kù)的大約80%的分量。而作為在實(shí)現(xiàn)STL過(guò)程中扮演關(guān)鍵角色的模板則充斥了幾乎整個(gè)C++標(biāo)準(zhǔn)函數(shù)庫(kù)。在這里,我們有必要看一看C++標(biāo)準(zhǔn)函數(shù)庫(kù)里包含了哪些內(nèi)容,其中又有哪些是屬于標(biāo)準(zhǔn)模板庫(kù)(即STL)的。

C++標(biāo)準(zhǔn)函數(shù)庫(kù)為C++程序員們提供了一個(gè)可擴(kuò)展的基礎(chǔ)性框架。我們從中可以獲得極大的便利,同時(shí)也可以通過(guò)繼承現(xiàn)有類,自己編制符合接口規(guī)范的容器、算法、迭代子等方式對(duì)之進(jìn)行擴(kuò)展。它大致包含了如下幾個(gè)組件:

C標(biāo)準(zhǔn)函數(shù)庫(kù),基本保持了與原有C語(yǔ)言程序庫(kù)的良好兼容,盡管有些微變化。人們總會(huì)忍不住留戀過(guò)去的美好歲月,如果你曾經(jīng)是一個(gè)C程序員,對(duì)這一點(diǎn)一定體會(huì)頗深。或許有一點(diǎn)會(huì)讓你覺得奇怪,那就是在C++標(biāo)準(zhǔn)庫(kù)中存在兩套C的函數(shù)庫(kù),一套是帶有.h擴(kuò)展名的(比如),而另一套則沒有(比如)。它們確實(shí)沒有太大的不同。

語(yǔ)言支持(language support)部分,包含了一些標(biāo)準(zhǔn)類型的定義以及其他特性的定義,這些內(nèi)容,被用于標(biāo)準(zhǔn)庫(kù)的其他地方或是具體的應(yīng)用程序中。

診斷(diagnostics)部分,提供了用于程序診斷和報(bào)錯(cuò)的功能,包含了異常處理(exception handling),斷言(assertions),錯(cuò)誤代碼(error number codes)三種方式。

通用工具(general utilities)部分,這部分內(nèi)容為C++標(biāo)準(zhǔn)庫(kù)的其他部分提供支持,當(dāng)然你也可以在自己的程序中調(diào)用相應(yīng)功能。比如:動(dòng)態(tài)內(nèi)存管理工具,日期/時(shí)間處理工具。記住,這里的內(nèi)容也已經(jīng)被泛化了(即采用了模板機(jī)制)。

字符串(string)部分,用來(lái)代表和處理文本。它提供了足夠豐富的功能。事實(shí)上,文本是一個(gè)string對(duì)象,它可以被看作是一個(gè)字符序列,字符類型可能是char,或者wchar_t等等。string可以被轉(zhuǎn)換成char*類型,這樣便可以和以前所寫的C/C++代碼和平共處了。因?yàn)槟菚r(shí)侯除了char*,沒有別的。

國(guó)際化(internationalization)部分,作為OOP特性之一的封裝機(jī)制在這里扮演著消除文化和地域差異的角色,采用locale和facet可以為程序提供眾多國(guó)際化支持,包括對(duì)各種字符集的支持,日期和時(shí)間的表示,數(shù)值和貨幣的處理等等。畢竟,在中國(guó)和在美國(guó),人們表示日期的習(xí)慣是不同的。

容器(containers)部分,STL的一個(gè)重要組成部分,涵蓋了許多數(shù)據(jù)結(jié)構(gòu),比如前面曾經(jīng)提到的鏈表,還有:vector(類似于大小可動(dòng)態(tài)增加的數(shù)組)、queue(隊(duì)列)、stack(堆棧)……。string也可以看作是一個(gè)容器,適用于容器的方法同樣也適用于string。現(xiàn)在你可以輕松的完成數(shù)據(jù)結(jié)構(gòu)課程的家庭作業(yè)了。

算法(algorithms)部分,STL的一個(gè)重要組成部分,包含了大約70個(gè)通用算法,用于操控各種容器,同時(shí)也可以操控內(nèi)建數(shù)組。比如:find用于在容器中查找等于某個(gè)特定值的元素,for_each用于將某個(gè)函數(shù)應(yīng)用到容器中的各個(gè)元素上,sort用于對(duì)容器中的元素排序。所有這些操作都是在保證執(zhí)行效率的前提下進(jìn)行的,所以,如果在你使用了這些算法之后程序變得效率底下,首先一定不要懷疑這些算法本身,仔細(xì)檢查一下程序的其他地方。

迭代器(iterators)部分,STL的一個(gè)重要組成部分,如果沒有迭代器的撮合,容器和算法便無(wú)法結(jié)合的如此***。事實(shí)上,每個(gè)容器都有自己的迭代器,只有容器自己才知道如何訪問自己的元素。它有點(diǎn)像指針,算法通過(guò)迭代器來(lái)定位和操控容器中的元素。

數(shù)值(numerics)部分,包含了一些數(shù)學(xué)運(yùn)算功能,提供了復(fù)數(shù)運(yùn)算的支持。

輸入/輸出(input/output)部分,就是經(jīng)過(guò)模板化了的原有標(biāo)準(zhǔn)庫(kù)中的iostream部分,它提供了對(duì)C++程序輸入輸出的基本支持。在功能上保持了與原有iostream的兼容,并且增加了異常處理的機(jī)制,并支持國(guó)際化(internationalization)。

總體上,在C++標(biāo)準(zhǔn)函數(shù)庫(kù)中,STL主要包含了容器、算法、迭代器。string也可以算做是STL的一部分。

STL和C++標(biāo)準(zhǔn)函數(shù)庫(kù)

圖1:STL和C++標(biāo)準(zhǔn)函數(shù)庫(kù)

1.3.3 STL和GP,GP和OOP

正如前面所提到的,在STL的背后蘊(yùn)含著泛型化程序設(shè)計(jì)(GP)的思想,在這種思想里,大部分基本算法被抽象,被泛化,獨(dú)立于與之對(duì)應(yīng)的數(shù)據(jù)結(jié)構(gòu),用于以相同或相近的方式處理各種不同情形。這一思想和面向?qū)ο蟮某绦蛟O(shè)計(jì)思想(OOP)不盡相同,因?yàn)椋贠OP中更注重的是對(duì)數(shù)據(jù)的抽象,即所謂抽象數(shù)據(jù)類型(Abstract Data Type),而算法則通常被附屬于數(shù)據(jù)類型之中。

幾乎所有的事情都可以被看作類或者對(duì)象(即類的實(shí)例),通常,我們所看到的算法被作為成員函數(shù)(member function)包含在類(class)中,類和類則構(gòu)成了錯(cuò)綜復(fù)雜的繼承體系。

盡管在象C++這樣的程序設(shè)計(jì)語(yǔ)言中,你還可以用全局函數(shù)來(lái)表示算法,但是在類似于Java這樣的純面向?qū)ο蟮恼Z(yǔ)言中,全局函數(shù)已經(jīng)被"勒令禁止"了。

因此,用Java來(lái)模擬GP思想是頗為困難的。如果你對(duì)前述的STL歷史還有印象的話,應(yīng)該記得Alexander Stepanove也曾用基于OOP的語(yǔ)言嘗試過(guò)實(shí)現(xiàn)GP思想,但是效果并不好,包括沒有引入模板之前的C++語(yǔ)言。站在巨人的肩膀上,我們可以得出這樣的結(jié)論,在OOP中所體現(xiàn)的思想與GP的思想確實(shí)是相異的。C++并不是一種純面向?qū)ο蟮某绦蛟O(shè)計(jì)語(yǔ)言,它的絕妙之處,就在于既滿足了OOP,又成全了GP。

對(duì)于后者,模板立下了汗馬功勞。另外,需要指出的是,盡管GP和OOP有諸多不同,但這種不同還不至于到"水火不容"的地步。并且,在實(shí)際運(yùn)用的時(shí)候,兩者的結(jié)合使用往往可以使問題的解決更為有效。作為GP思想實(shí)例的STL本身便是一個(gè)很好的范例,如果沒有繼承,不知道STL會(huì)是什么樣子,似乎沒有人做過(guò)這樣的試驗(yàn)。

1.4 STL的不同實(shí)現(xiàn)版本

相信你對(duì)STL的感性認(rèn)識(shí)應(yīng)該有所提高了,是該做一些實(shí)際的工作了,那么我們首先來(lái)了解一下STL的不同實(shí)現(xiàn)版本。ANSI/ISO C++文件中的STL是一個(gè)僅被描述在紙上的標(biāo)準(zhǔn),對(duì)于諸多C++編譯器而言,需要有各自實(shí)際的STL,它們或多或少的實(shí)現(xiàn)了標(biāo)準(zhǔn)中所描述的內(nèi)容,這樣才能夠?yàn)槲覀兯谩V杂胁煌膶?shí)現(xiàn)版本,則存在諸多原因,有歷史的原因,也有各自編譯器生產(chǎn)廠商的原因。以下是幾個(gè)常見的STL實(shí)現(xiàn)版本。

1.4.1 HP STL

HP STL是所有其它STL實(shí)現(xiàn)版本的根源。它是STL之父Alexander Stepanov在惠普的Palo Alto實(shí)驗(yàn)室工作時(shí),和Meng Lee共同完成的,是***個(gè)STL的實(shí)現(xiàn)版本(參見1.2節(jié))。這個(gè)STL是開放源碼的,所以它允許任何人免費(fèi)使用、復(fù)制、修改、發(fā)布和銷售該軟件和相關(guān)文檔,前提是必須在所有相關(guān)文件中加入HP STL的版本信息和授權(quán)信息。現(xiàn)在已經(jīng)很少直接使用這個(gè)版本的STL了。

1.4.2 P.J. Plauger STL

P. J. Plauger STL屬于個(gè)人作品,由P. J. Plauger本人實(shí)現(xiàn),是HP STL的一個(gè)繼承版本,因此在其所有頭文件中都含有HP STL的相關(guān)聲明,同時(shí)還有P. J. Plauger本人的版權(quán)聲明。P. J. Plauger是標(biāo)準(zhǔn)C中stdio庫(kù)的早期實(shí)現(xiàn)者,現(xiàn)在是C/C++ User's Journal的主編,與Microsoft保持著良好的關(guān)系。P. J. Plauger STL便是被用于Microsoft的Visual C++中的。在Windows平臺(tái)下的同類版本中,其性能不錯(cuò),但是queue組件(隊(duì)列,一種容器)的效率不理想,同時(shí)由于Visual C++對(duì)C++語(yǔ)言標(biāo)準(zhǔn)的支持不是很好(至少直到VC6.0為止,還是如此),因此一定程度上影響了P. J. Plauger STL的性能。

此外,該版本的源代碼可讀性較差,你可以在VC的Include子目錄下找到所有源文件(比如:C:\Program Files\Microsoft Visual Studio\VC98\Include)。因?yàn)椴皇情_放源碼的(open source),所以這些源代碼是不能修改和銷售的,目前P.J. Plauger STL由Dinkumware公司提供相關(guān)服務(wù),詳情請(qǐng)見http://www.dinkumware.com。據(jù)稱Visual Studio.NET中的Visual C++.NET(即VC7.0),對(duì)C++標(biāo)準(zhǔn)的支持有所提高,并且多了以哈希表(hash table)為基礎(chǔ)而實(shí)現(xiàn)的map容器,multimap容器和set容器。

1.4.3 Rouge Wave STL

Rouge Wave STL是由Rouge Wave公司實(shí)現(xiàn)的,也是HP STL的一個(gè)繼承版本,除了HP STL的相關(guān)聲明之外,還有Rouge Wave公司的版權(quán)聲明。同時(shí),它也不是開放源碼的,因此無(wú)法修改和銷售。該版本被Borland C++ Builder所采用,你可以在C++ Builder的Include子目錄下找到所有頭文件(比如:C:\Program Files\Borland\Cbuilder5\Include)。盡管Rouge Wave STL的性能不是很好,但由于C++ Builder對(duì)C++語(yǔ)言標(biāo)準(zhǔn)的支持還算不錯(cuò),使其表現(xiàn)在一定程度上得以改善。

此外,其源代碼的可讀性較好。可以從如下網(wǎng)站得到更詳細(xì)的情況介紹:http://www.rougewave.com。遺憾的是該版本已有一段時(shí)間沒有更新且不完全符合標(biāo)準(zhǔn)。因此在Borland C++ Builder 6.0中,它的地位被另一個(gè)STL的實(shí)現(xiàn)版本--STLport(見后)取代了。但是考慮到與以前版本的兼容,C++ Builder 6.0還是保留了Rouge Wave STL,只是如果你想查看它的源代碼的話,需要在別的目錄中才能找到(比如:C:\Program Files\Borland\Cbuilder6\Include\oldstl)。

1.4.4 STLport

STLport最初源于俄國(guó)人Boris Fomitchev的一個(gè)開發(fā)項(xiàng)目,主要用于將SGI STL的基本代碼移植到其他諸如C++Builder或者是Visual C++這樣的主流編譯器上。因?yàn)镾GI STL屬于開放源碼,所以STLport才有權(quán)這樣做。目前STLport的***版本是4.5。可以從如下網(wǎng)站得到更詳細(xì)的情況介紹:http://www.stlport.org,可以免費(fèi)下載其源代碼。STLport已經(jīng)被C/C++技術(shù)委員會(huì)接受成為工業(yè)標(biāo)準(zhǔn),且在許多平臺(tái)上都支持。

根據(jù)測(cè)試STLport的效率比VC中的STL要快。比Rouge Wave STL更符合標(biāo)準(zhǔn),也更容易移植。Borland C++ Builder已經(jīng)在其6.0版中加入了對(duì)STLport的支持,它使用的STLport就是4.5版的,C++ Builder 6.0同時(shí)還提供了STLport的使用說(shuō)明。你可以在C++ Builder的Include\Stlport子目錄下找到所有頭文件(比如:C:\Program Files\Borland\Cbuilder6\Include\Stlport)。

1.4.5 SGI STL

SGI STL是由Silicon Graphics Computer System, Inc公司實(shí)現(xiàn)的,其設(shè)計(jì)者和編寫者包括Alexander Stepanov和Matt Austern,同樣它也是HP STL的一個(gè)繼承版本。它屬于開放源碼,因此你可以修改和銷售它。SGI STL被GCC(linux下的C++編譯器)所采用,你可以在GCC的Include子目錄下找到所有頭文件(比如:C:\cygnus\cygwin-b20\include\g++\include)。由于GCC對(duì)C++語(yǔ)言標(biāo)準(zhǔn)的支持很好,SGI STL在linux平臺(tái)上的性能相當(dāng)出色。此外,其源代碼的可讀性也很好。可以從如下網(wǎng)站得到更詳細(xì)的情況介紹:http://www.sgi.com,可以免費(fèi)下載其源代碼。目前的***版本是3.3。

STL家族的譜系

圖2:STL家族的譜系

責(zé)任編輯:于鐵 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2011-07-20 13:57:06

C++STL

2011-07-20 14:12:48

2010-01-11 09:56:07

C++編程實(shí)例

2011-07-14 16:26:01

2011-07-14 17:02:09

C++指針

2011-07-20 15:58:53

C++引用

2011-07-13 11:12:43

C++MFC

2011-07-13 16:49:59

C++

2011-06-21 15:00:07

JAVAC++

2010-01-19 13:17:05

C++數(shù)據(jù)類型

2011-07-20 16:43:34

C++

2011-06-21 10:37:56

const

2010-02-05 10:46:10

C++文件流

2011-07-14 16:56:21

2010-01-12 15:46:29

測(cè)試C++ Test

2011-07-14 23:27:05

C++引用

2010-01-19 18:51:17

C++類

2011-07-13 11:34:58

CC++時(shí)間函數(shù)

2011-07-20 17:16:50

C++重載函數(shù)

2011-07-20 15:26:52

C++
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久午夜老司机| 欧美成熟视频| 色综合久久久久综合99| 狠狠色狠狠色综合人人| 免费在线观看黄网站| 豆花视频一区二区| 亚洲成人免费影院| 国产欧美一区二区视频| 欧美另类视频在线观看| 欧美变态网站| 欧洲激情一区二区| 伊人久久av导航| 国产美女自慰在线观看| 午夜久久影院| 亚洲国产精品一区二区久| 香港三级韩国三级日本三级| 日本人妖在线| 日本不卡一区二区| 久久亚洲精品一区| 国产免费a级片| 毛片在线导航| 国产亚洲精品久| 成人午夜黄色影院| 日韩激情在线播放| 欧洲杯足球赛直播| 日韩一区二区免费高清| 日韩a在线播放| h视频在线播放| 丰满白嫩尤物一区二区| 日本一区二区不卡| 国产一级中文字幕| av永久不卡| 日韩精品最新网址| 无人在线观看的免费高清视频 | 肉色丝袜一区二区| 久久手机免费视频| 午夜久久久久久久| 日韩毛片免费看| 午夜伦理一区二区| 杨幂一区欧美专区| 无码精品一区二区三区在线 | 国产精品丝袜久久久久久app| 91亚洲国产成人精品性色| 国产在线观看你懂的| 欧美一级精品| 亚洲精品在线观| 中文字幕天天干| 国模精品视频| 亚洲精品一二三| 日韩欧美精品在线不卡| 黑人操亚洲女人| 蜜臀av一区二区| **欧美日韩vr在线| 一区二区视频免费看| 国产一区99| 精品毛片乱码1区2区3区| 手机在线成人免费视频| sm在线观看| 国产精品大尺度| 欧美精品一区二区三区在线四季| 亚洲欧美强伦一区二区| 久久成人av少妇免费| 国产精品av电影| 国产情侣自拍av| 国内精品美女在线观看| 精品激情国产视频| 综合 欧美 亚洲日本| 综合亚洲色图| 日韩av中文字幕在线| 久久久国产精品久久久| 国产91在线精品| 婷婷久久综合九色国产成人| 中文有码久久| av观看在线| 亚洲欧美自拍偷拍| 欧美精品一区二区性色a+v| 日韩理伦片在线| 国产精品麻豆久久久| 日韩国产欧美精品| 欧美一区二区三区少妇| 久久精品亚洲麻豆av一区二区| 精品欧美日韩在线| 五月婷婷六月丁香| 91在线免费播放| 国产一区免费| 手机在线不卡av| 91热门视频在线观看| 国产精品嫩草在线观看| 免费看黄网站在线观看| 成人av一区二区三区| 国产精品亚洲综合| 无码国产色欲xxxx视频| 9久草视频在线视频精品| 亚洲一区二区三区视频| 精品女同一区二区三区| 成人黄色一级视频| 精品国产一区二区三区麻豆小说| 无码国产精品一区二区色情男同| 97se亚洲国产综合在线| 日本一区二区三区www| 国产youjizz在线| 中文字幕av一区 二区| 一本久道久久综合狠狠爱亚洲精品| 999在线视频| 日韩美女视频一区二区| 国产精品av免费观看| hd国产人妖ts另类视频| 午夜av一区二区三区| 日韩精品一区二区三区不卡 | 国产精品99一区| 亚洲自拍偷拍另类| 福利一区福利二区| 欧美视频小说| av在线下载| 精品福利在线视频| 午夜激情在线观看视频| 久久91超碰青草在哪里看| 精品久久久久久久久久久久包黑料| 丰满岳乱妇一区二区| 免费短视频成人日韩| 自拍视频国产精品| 日韩欧美激情视频| 蜜桃91丨九色丨蝌蚪91桃色| 91亚洲精品在线观看| 天天操天天爱天天干| 欧美激情资源网| 免费拍拍拍网站| 欧美123区| 欧美变态口味重另类| 波多野结衣办公室33分钟| 不卡日本视频| 欧美亚洲国产日韩2020| 91中文字幕在线视频| 97久久精品人人做人人爽| 亚洲国产高清国产精品| 69av成人| 欧美精品在线一区二区| mm131美女视频| 欧美日韩1区| 国产日韩精品视频| 视频一区二区三区在线看免费看| 国产精品国产三级国产普通话蜜臀| 男女猛烈激情xx00免费视频| 日本欧美一区| 亚洲精品99久久久久| 国产稀缺精品盗摄盗拍| 久久天堂精品| 国产一区视频观看| h视频在线免费观看| 在线观看中文字幕不卡| 一级黄色片毛片| 亚洲无中文字幕| 日韩av电影中文字幕| 亚洲欧美黄色片| 国产精品乱人伦| 熟妇人妻va精品中文字幕| 加勒比色老久久爱综合网| www.国产精品一二区| 国产suv精品一区二区33| www.激情成人| 免费人成自慰网站| 欧美不卡在线观看| 久久亚洲精品毛片| 国产精品久久久久久免费播放| 久久综合久久鬼色| 免费无遮挡无码永久视频| 伊人久久大香| 亚洲一区二区黄| 国产精品视频免费播放| 99国产精品久久久久久久久久久 | 182午夜在线观看| 国产欧美久久一区二区三区| 97超级碰碰人国产在线观看| 深夜福利在线看| 亚洲成人动漫精品| 香蕉视频污视频| 欧美精品综合| 91久久精品www人人做人人爽| 老司机在线看片网av| 337p亚洲精品色噜噜狠狠| 懂色av粉嫩av蜜臀av一区二区三区| 日日夜夜免费精品| 热re99久久精品国99热蜜月| 欧美黑人巨大xxxxx| 欧美mv日韩mv亚洲| 免费网站看av| 99久久婷婷国产| 国产免费成人在线| 成人久久一区| 91精品久久久久| 黄色网址免费在线观看| 在线播放国产精品二区一二区四区| 久久嫩草捆绑紧缚| 国产精品一区二区不卡| 乱熟女高潮一区二区在线| av一级久久| 色综合久久久888| 欧美熟女一区二区| 欧美视频专区一二在线观看| 妺妺窝人体色WWW精品| 蜜桃精品在线观看| 欧美一区二区视频在线播放| 红杏aⅴ成人免费视频| 国产91精品青草社区| 成人在线二区| 欧美一区二区精品| 麻豆亚洲av熟女国产一区二| 91蜜桃婷婷狠狠久久综合9色| 日韩欧美xxxx| 亚洲经典一区| 精品乱色一区二区中文字幕| 欧美黄色三级| 欧美成人在线影院| 天天综合天天色| 在线看日韩精品电影| av网站免费在线看| 岛国一区二区三区| 亚洲色精品三区二区一区| 91一区在线| 精品国产免费久久久久久尖叫| 欧美日韩视频免费观看| 久久国产精品久久久久| 亚洲AV成人无码一二三区在线| 在线观看欧美黄色| 在线免费日韩av| www国产精品av| 久久久久久久久久毛片| 一区二区三区导航| 国产高清免费在线| 精品一区欧美| 粉嫩av一区二区三区免费观看 | 国产一区二区三区91| 亚洲淫片在线视频| 日韩在线免费| 久久久噜噜噜久噜久久| 欧美日韩在线看片| 亚洲人成啪啪网站| 四虎精品一区二区三区| 欧美日韩中文字幕一区二区| 日韩精品视频播放| 亚洲六月丁香色婷婷综合久久 | 久久高清无码视频| 中文字幕免费一区| 性色av蜜臀av色欲av| 国产一区在线观看视频| 黄色三级视频片| 精品91视频| 欧美极品少妇无套实战| 日韩电影免费网址| 欧美精品在线一区| 韩国精品福利一区二区三区| 91久久久精品| 欧美成人黄色| 国产成人精品av| 不卡专区在线| 欧美成人精品一区| caopen在线视频| 久久伊人精品一区二区三区| 欧美日韩在线资源| 中文字幕在线精品| 国产露出视频在线观看| 亚洲精品一区中文字幕乱码| 亚洲国产精品成人久久蜜臀| 欧美亚洲动漫另类| 中文字幕免费视频观看| 日韩欧美精品在线观看| 五月天婷婷综合网| 亚洲v日本v欧美v久久精品| 草视频在线观看| 一区二区视频在线看| 一区二区三区影视| 亚洲天堂成人网| 又色又爽的视频| 亚洲欧美一区二区三区孕妇| 日本黄色录像视频| 亚洲欧洲99久久| 国产成人久久久久| 亚洲精品国产高清久久伦理二区| 四虎精品免费视频| 一区二区三区在线不卡| 欧美成人aaa片一区国产精品| 国产精品福利一区二区三区| 91香蕉视频在线播放| 亚洲欧美日韩一区| 久久久久久久久久久久久女过产乱| 亚洲免费观看高清完整| 欧美人与禽zozzo禽性配| 亚洲一二三四区不卡| 日本一级黄色录像| 岛国视频午夜一区免费在线观看| 久久精品国产亚洲av无码娇色 | 国产美女99p| 欧美顶级毛片在线播放| 国产一区免费| 蜜臀久久99精品久久一区二区| 亚洲精品日韩精品| 亚洲色图插插| 国产精品无码人妻一区二区在线 | av综合在线播放| 成年人在线观看av| 亚洲国产激情av| 久久艹精品视频| 日韩欧美国产一区二区| 中文字幕视频一区二区| 欧美一区二区三区在| 男人天堂av网| 亚洲网址你懂得| 久热国产在线| 国内偷自视频区视频综合| 天然素人一区二区视频| 91观看网站| 色天下一区二区三区| 永久久久久久| 亚洲精品欧洲| 日本中文字幕影院| 国产精品88av| 无码h肉动漫在线观看| 一区二区三区四区五区视频在线观看 | 在线能看的av网站| 99精品一区二区三区| 亚洲精品国产精品国自| 一区二区三区成人| 天堂网一区二区| 日韩三级免费观看| 日夜干在线视频| 欧美激情videoshd| 日本综合视频| 精品视频高清无人区区二区三区| 日本一区二区高清不卡| 六月婷婷在线视频| 九九九久久久精品| 无码人妻精品一区二区三应用大全 | 国产男男gay体育生白袜| 日韩精品免费视频| 菠萝菠萝蜜在线观看| 国产精品99蜜臀久久不卡二区| 第四色在线一区二区| 伊人色综合影院| 久久精品国产清高在天天线| 欧洲在线免费视频| 国产精品免费av| 国产黄色免费观看| 亚洲成人激情在线观看| www视频在线看| 国产精品日韩在线观看| 欧美日日夜夜| 国产成人在线小视频| 麻豆精品网站| www.超碰97| 亚洲国产成人av| www.天堂在线| 久久久精品国产网站| 日本一道高清亚洲日美韩| 精品久久蜜桃| 亚洲精品女人| 国产精品无码久久久久久| 亚洲小说欧美激情另类| 国产av一区二区三区精品| 日韩最新在线视频| 激情欧美一区二区三区黑长吊| 久久久99国产精品免费| 99国产精品自拍| 丰满少妇一区二区三区| 日韩欧美一区二区三区久久| 天天操天天操天天干| 久久久欧美一区二区| 91精品久久久久久综合五月天| 先锋影音男人资源| 国产在线精品一区在线观看麻豆| 久热这里有精品| 日韩一区二区三区高清免费看看| av免费在线观看网站| 亚洲精品日韩av| 欧美一区在线看| 激情小说欧美色图| 国产精品欧美一级免费| 日本视频在线观看免费| 日韩精品在线视频美女| 成人欧美一区二区三区的电影| 久久综合给合久久狠狠色| 午夜一区不卡| 久久成人激情视频| 欧美日韩亚洲精品一区二区三区| 美州a亚洲一视本频v色道| 国产精品91久久| 日韩电影一区| 国产性生活一级片| 亚洲一区二区三区在线看| 少妇av在线播放| 国产经典一区二区| 欧美第一精品| 999在线精品视频| 亚洲香蕉伊在人在线观| 女人天堂在线| 国产在线高清精品| 黑丝一区二区三区| 一本色道综合久久欧美日韩精品 | 久久综合狠狠综合久久综青草 | 中文字幕亚洲一区二区va在线| 国产欧美日韩综合精品一区二区三区|