C 學習筆記之vector類詳解

2021-07-10 17:51:02 字數 1849 閱讀 7860

1. 在c++中的詳細說明

vector是c++標準模板庫中的部分內容,它是乙個多功能的,能夠操作多種資料結構和演算法的模板類和函式庫。

vector之所以被認為是乙個容器,是因為它能夠像容器一樣存放各種型別的物件,

簡單地說,vector是乙個能夠存放任意型別的動態陣列,能夠增加和壓縮資料。

2. 使用vector,

必須在你的標頭檔案中包含下面的**:

#include

vector屬於std命名域,

建議使用全域性的命名域方式:

using namespace std;

3. 初始化   

vector                 // 建立乙個空的vector。

vector c1(c2)          // 複製乙個vector

vector c(n)            // 建立乙個vector,含有n個資料,資料均已預設構造產生

vector c(n, elem)      // 建立乙個含有n個elem拷貝的vector

vector c(beg,end)      // 建立乙個含有n個elem拷貝的vector

4. 析構函式

c.~vector ()           // 銷毀所有資料,釋放記憶體

5. 成員函式

c.assign(beg,end)c.assign(n,elem)

將[beg; end)區間中的資料賦值給c。將n個elem的拷貝賦值給c。

c.at(idx)

傳回索引idx所指的資料,如果idx越界,丟擲out_of_range。

c.back()      // 傳回最後乙個資料,不檢查這個資料是否存在。

c.begin()     // 傳回迭代器中的第乙個資料位址。

c.capacity()  // 返回容器中資料個數。

c.clear()     // 移除容器中所有資料。

c.empty()     // 判斷容器是否為空。

c.end()       // 指向迭代器中末端元素的下乙個,指向乙個不存在元素。

c.erase(pos)  // 刪除pos位置的資料,傳回下乙個資料的位置。

c.erase(beg,end)  //刪除[beg,end)區間的資料,傳回下乙個資料的位置。

c.front()     // 傳回第乙個資料。

get_allocator // 使用建構函式返回乙個拷貝。

c.insert(pos,elem)    // 在pos位置插入乙個elem拷貝,傳回新資料位置。

c.insert(pos,n,elem)  // 在pos位置插入n個elem資料。無返回值。

c.insert(pos,beg,end) // 在pos位置插入在[beg,end)區間的資料。無返回值。

c.max_size()       // 返回容器中最大資料的數量。

c.pop_back()       // 刪除最後乙個資料。

c.push_back(elem)  // 在尾部加入乙個資料。

c.rbegin()         // 傳回乙個逆向佇列的第乙個資料。

c.rend()           // 傳回乙個逆向佇列的最後乙個資料的下乙個位置。

c.resize(num)      // 重新指定佇列的長度。

c.reserve()        // 保留適當的容量。

c.size()           // 返回容器中實際資料的個數。

c1.swap(c2)

swap(c1,c2)        // 將c1和c2元素互換。同上操作。

operator         // 返回容器中指定位置的乙個引用。

STL之vector學習筆記

參考sgi stl 及 侯捷 stl原始碼剖析 概述 vector是動態空間,隨著元素的加入,它的內部機制會自行擴充空間以容納新元素。但是它不是單純地 配置新空間 資料移動 釋放舊空間,它實際配置的大小會比客戶需求要大一點定義 sgi stl的vector實現於stl vector.h中,而不是ve...

c STL 之 vector 學習筆記

定義乙個二維陣列 可以看作是乙個封裝好的動態陣列 vector int a 不止 int string char 型別,還可以自己定義結構體型別 結構體相關例題見?vector pta 7 10 宿舍誰最高?vector pta 7 7 計算職工工資 a.push back 10 插入 10 a.e...

C 11學習筆記2之vector

include include include using namespace std int main vb有1個元素,值為10 vectorvc 10,1 vc有10個元素,每乙個的值為1 vectorvd vd有2個元素,分別為10,1 return 0 是用來構造vector物件的 是用來列...