STL源碼初步接觸

   STL = Standard Template Library,直譯過來是:標準模板庫,是惠普實驗室開發(fā)的一系列軟件的統(tǒng)稱。從根本上說,STL是一些“容器”的集合,這些“容器”有l(wèi)ist,vector,set,map等,STL也是算法和其他一些組件的集合。這里的“容器”和算法的集合指的是世界上很多聰明人很多年的杰作。STL的目的是標準化組件,這樣就不用重新開發(fā),可以使用現成的組件。STL現在是C++的一部分,因此不用額外安裝什么。STL所實現的,是依據泛型思維架設起來的一個概念結構。說了這么多還是不知道STL是個什么東東,今天只是初接觸這個概念,感覺很高深的樣子,先這樣理解吧,STL就是一個倉庫,一個存放各種工具的倉庫。它的工具分為六大類(六大組件) :

容器(containers):各種數據結構,如Vector,list,deque,set,map,用來存放底層數據。一般有序列式(下面要寫的Vector就是個這種)、關聯式等。

算法(algorithms):各種常用算法如:sort,search,copy,erase……

迭代器(iterator):扮演容器與算法之間的膠合劑,是所謂的“泛型指針”,共5種類型,以及他們的衍生變化。所有的STL容器都附帶有自己專屬的迭代器。原生指針也是一種迭代器。

仿函數(functor):行為類似函數可作為算法的某種策略。一般函數指針可認為是俠義的仿函數。

配接器(adapter):一種用來修飾容器,或仿函數,或迭代器接口的東西。

配置器(allocators)負責空間配置與管理。配置器是一個實現了動態(tài)空間配置、空間管理、空間釋放的class template。

延伸閱讀

學習是年輕人改變自己的最好方式-Java培訓,做最負責任的教育,學習改變命運,軟件學習,再就業(yè),大學生如何就業(yè),幫大學生找到好工作,lphotoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網站設計培訓,網站建設培訓學習是年輕人改變自己的最好方式