日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 單片機(jī) > C語(yǔ)言與CPP編程
[導(dǎo)讀]前言源碼之前,了無秘密。上一篇,我們剖析了STL迭代器源碼與traits編程技法?,這一篇我們來學(xué)習(xí)下容器。在STL編程中,容器是我們經(jīng)常會(huì)用到的一種數(shù)據(jù)結(jié)構(gòu),容器分為序列式容器和關(guān)聯(lián)式容器。兩者的本質(zhì)區(qū)別在于:序列式容器是通過元素在容器中的位置順序存儲(chǔ)和訪問元素,而關(guān)聯(lián)容器則是...

前言

源碼之前,了無秘密。

上一篇,我們剖析了 STL 迭代器源碼與 traits 編程技法?,這一篇我們來學(xué)習(xí)下容器。

在 STL 編程中,容器是我們經(jīng)常會(huì)用到的一種數(shù)據(jù)結(jié)構(gòu),容器分為序列容器和關(guān)聯(lián)式容器。

兩者的本質(zhì)區(qū)別在于:序列式容器是通過元素在容器中的位置順序存儲(chǔ)和訪問元素,而關(guān)聯(lián)容器則是通過鍵 (key) 存儲(chǔ)和讀取元素。

本篇著重剖析序列式容器相關(guān)背后的知識(shí)點(diǎn)。

容器分類

前面提到了,根據(jù)元素存儲(chǔ)方式的不同,容器可分為序列式和關(guān)聯(lián)式,那具體的又有哪些分類呢,這里我畫了一張圖來看一下。

限于篇幅,這篇文章小賀會(huì)來重點(diǎn)講解一下經(jīng)常使用到的那些容器,比如 vector,list,deque,以及衍生的棧和隊(duì)列其背后核心的設(shè)計(jì)和奧秘,不多 BB, 馬上就來分析。

vector

寫 C 的小伙伴們,應(yīng)該對(duì) vector 都非常熟悉了,vector 基本能夠支持任何類型的對(duì)象,同時(shí)它也是一個(gè)可以動(dòng)態(tài)增長(zhǎng)的數(shù)組,使用起來非常的方便。

但如果我問你,知道它是如何做到動(dòng)態(tài)擴(kuò)容的嗎?哎,是不是一時(shí)半會(huì)答不上來了,哈哈,沒事,我們一起來看看。

vector 基本數(shù)據(jù)結(jié)構(gòu)

基本上,STL 里面所有的容器的源碼都包含至少三個(gè)部分:

  • 迭代器,遍歷容器的元素,控制容器空間的邊界和元素的移動(dòng);
  • 構(gòu)造函數(shù),滿足容器的多種初始化;
  • 屬性的獲取,比如 begin(),end()等;
vector 也不例外,其實(shí)看了源碼之后就發(fā)現(xiàn),vector 相反是所有容器里面最簡(jiǎn)單的一種。

template?<class?T,?class?Alloc?=?alloc>
class?vector?{

public:
???//?定義?vector?自身的嵌套型別
????typedef?T?value_type;
????typedef?value_type*?pointer;
????typedef?const?value_type*?const_pointer;
????//?定義迭代器,?這里就只是一個(gè)普通的指針
????typedef?value_type*?iterator;
????typedef?const?value_type*?const_iterator;
????typedef?value_type
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉