正如前面所提到的,在STL的背后蘊(yùn)含著泛型化程序設(shè)計(jì)(GP)的思想,在這種思想里,大部分基本算法被抽象,被泛化,獨(dú)立于與之對應(yīng)的數(shù)據(jù)結(jié)構(gòu),用于以相同或相近的方式處理各種不同情形。這一思想和面向?qū)ο蟮某绦蛟O(shè)計(jì)思想(OOP)不盡相同,因?yàn)椋贠OP中更注重的是對數(shù)據(jù)的抽象,即所謂抽象數(shù)據(jù)類型(Abstract Data Type),而算法則通常被附屬于數(shù)據(jù)類型之中。幾乎所有的事情都可以被看作類或者對象(即類的實(shí)例),通常,我們所看到的算法被作為成員函數(shù)(member function)包含在類(class)中,類和類則構(gòu)成了錯(cuò)綜復(fù)雜的繼承體系。
C++并不是一種純面向?qū)ο蟮某绦蛟O(shè)計(jì)語言,它的絕妙之處,就在于既滿足了OOP,又成全了GP。對于后者,模板立下了汗馬功勞。另外,需要指出的是,盡管GP和OOP有諸多不同,但這種不同還不至于到"水火不容"的地步。并且,在實(shí)際運(yùn)用的時(shí)候,兩者的結(jié)合使用往往可以使問題的解決更為有效。作為GP思想實(shí)例的STL本身便是一個(gè)很好的范例,如果沒有繼承,不知道STL會是什么樣子,似乎沒有人做過這樣的試驗(yàn)。
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庫的早期實(shí)現(xiàn)者,現(xiàn)在是C/C++ User's Journal的主編,與Microsoft保持著良好的關(guān)系。P. J. Plauger STL便是被用于Microsoft的Visual C++中的。在Windows平臺下的同類版本中,其性能不錯(cuò),但是queue組件(隊(duì)列,一種容器)的效率不理想,同時(shí)由于Visual C++對C++語言標(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ù),詳情請見http://www.dinkumware.com。據(jù)稱Visual Studio.NET中的Visual C++.NET(即VC7.0),對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í),它也不是開放源碼的,因此無法修改和銷售。該版本被Borland C++ Builder所采用,你可以在C++ Builder的Include子目錄下找到所有頭文件(比如:C:\Program Files\Borland\Cbuilder5\Include)。盡管Rouge Wave STL的性能不是很好,但由于C++ Builder對C++語言標(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最初源于俄國人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ù)委員會接受成為工業(yè)標(biāo)準(zhǔn),且在許多平臺上都支持。根據(jù)測試STLport的效率比VC中的STL要快。比Rouge Wave STL更符合標(biāo)準(zhǔn),也更容易移植。Borland C++ Builder已經(jīng)在其6.0版中加入了對STLport的支持,它使用的STLport就是4.5版的,C++ Builder 6.0同時(shí)還提供了STLport的使用說明。你可以在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對C++語言標(biāo)準(zhǔn)的支持很好,SGI STL在linux平臺上的性能相當(dāng)出色。此外,其源代碼的可讀性也很好。可以從如下網(wǎng)站得到更詳細(xì)的情況介紹:http://www.sgi.com,可以免費(fèi)下載其源代碼。目前的最新版本是3.3。

圖2:STL家族的譜系