c++中vector的使用和模擬實(shí)現(xiàn)
一、接口介紹
1、插入數(shù)據(jù)
void push_back(const T& x)
在當(dāng)前vector尾部插入x,如果容量不夠擴(kuò)大二倍。
iterator insert(iterator pos, const T& x)
在POS位置插入元素x
2、容量相關(guān)
size_t capacity()
返回當(dāng)前vector的容量(size+剩余容量)
size_t size()
返回當(dāng)前vector的元素個(gè)數(shù)
void resize(size_t n, const T& val = T())
改變當(dāng)前vector的size,如果n>size則大于部分初始值為val。(capacity的大小始終保持不變)
void reserve(size_t n)
改變當(dāng)前vector的capacity,如果n<capacity則不改變。
3、刪除數(shù)據(jù)
void pop_back()
如果vector不為空,刪除當(dāng)前vector的最后一個(gè)元素
iterator erase(iterator pos)
刪除POS位置的元素
4、運(yùn)算符重載
T& operator[](size_t pos)
[]運(yùn)算符重載,支持使用下標(biāo)訪問(wèn)vector
二、實(shí)現(xiàn)
#include<iostream>
#include<string.h>
#include<assert.h>
using namespace std;
namespace myvector
{
template<class T>
class vector
{
public:
typedef T* iterator;
iterator begin()
{
return start;
}
iterator end()
{
return finish;
}
//默認(rèn)構(gòu)造函數(shù)
vector()
:start(nullptr)
, finish(nullptr)
, end_of_storage(nullptr)
{}
//容量
size_t capacity()
{
return end_of_storage - start;
}
size_t size()
{
return finish - start;
}
void reserve(size_t n)
{
if (n > capacity())
{
//開(kāi)新空間
T* tmp = new T[n];
//拷貝舊空間的內(nèi)容
memcpy(tmp, start, sizeof(T)*size());
//改變?nèi)萘?
finish = tmp + size();
end_of_storage = tmp + n;
//釋放舊空間
T* tmp1 = start;
start = tmp;
tmp = nullptr;
}
}
void resize(size_t n, const T& val = T())
{
//判斷容量
if (n > capacity())
reserve(n);
//如果n<size
if (n < size())
{
finish = start + n;
}
else
{
while (finish != start + n)
{
*finish = val;
finish++;
}
}
}
//檢查空間
void check_capacity()
{
if (finish == end_of_storage)
{
//如果當(dāng)前不為空,就擴(kuò)2倍,為空就開(kāi)4個(gè)吧
size_t newcapacity = finish == nullptr ? 4 : capacity()*2;
reserve(newcapacity);
}
}
T& operator[](size_t pos)
{
assert(pos < size());
return start[pos];
}
//插入
void push_back(const T& x)
{
insert(finish,x);
}
iterator insert(iterator pos, const T& x)
{
assert(pos >= start && pos <= finish);
size_t pos1 = pos - start;
check_capacity();
//解決迭代器失效
pos = start + pos1;
//移動(dòng)數(shù)據(jù)
iterator end = finish;
while (end >= pos)
{
*(end + 1) = *end;
end--;
}
//插入數(shù)據(jù)
*pos = x;
finish++;
return pos;
}
//刪除數(shù)據(jù)
void pop_back()
{
assert(finish > start);
finish--;
}
iterator erase(iterator pos)
{
assert(pos >= start && pos < finish);
iterator it = pos + 1;
while (it != finish)
{
*(it - 1) = *it;
++it;
}
--finish;
return pos;
}
//析構(gòu)函數(shù)
~vector()
{
delete[] start;
start = finish = end_of_storage = nullptr;
}
private:
iterator start;
iterator finish;
iterator end_of_storage;
};
}
三、測(cè)試用例
void test1()
{
//測(cè)試默認(rèn)構(gòu)造和析構(gòu)函數(shù)
myvector::vector<int> v1;
}
void test2()
{
//測(cè)試push_back()、reserve、check_capacity、size、capacity
myvector::vector<int> v2;
//插入至少五個(gè)數(shù)據(jù),進(jìn)行一次擴(kuò)容,擴(kuò)容間接對(duì)size和capacity以及check_capacity進(jìn)行了測(cè)試
v2.push_back(1);
v2.push_back(2);
v2.push_back(3);
v2.push_back(4);
//v2.push_back(5);
for (size_t i = 0; i < v2.size(); i++)
cout << v2[i] << " ";
cout << endl;
//測(cè)試resize,變小變大
v2.resize(8,6);
for (size_t i = 0; i < v2.size(); i++)
cout << v2[i] << " ";
cout << endl;
v2.resize(4);
//測(cè)試[]
//正常訪問(wèn)
for (size_t i = 0; i < v2.size(); i++)
cout << v2[i] << " ";
cout << endl;
//越界訪問(wèn)
//cout << v2[v2.size()] << endl;
//cout << v2[-1] << endl;
//測(cè)試insert---將push_back使用insert插入也可以進(jìn)行檢查
myvector::vector<int>::iterator it = v2.begin();
it = v2.insert(it,0);
it = v2.insert(it + 2, 10);
for (size_t i = 0; i < v2.size(); i++)
cout << v2[i] << " ";
cout << endl;
//測(cè)試刪除
v2.pop_back();
v2.pop_back();
for (size_t i = 0; i < v2.size(); i++)
cout << v2[i] << " ";
cout << endl;
v2.erase(v2.begin());
for (size_t i = 0; i < v2.size(); i++)
cout << v2[i] << " ";
cout << endl;
}
四、迭代器失效
1、在vector的接口中,使用insert插入數(shù)據(jù)時(shí)可能導(dǎo)致迭代器失效,具體如下

2、刪除操作導(dǎo)致迭代器失效

3、迭代器失效的解決辦法
1)在vector中,解決迭代器失效的辦法是在插入、刪除等可能會(huì)導(dǎo)致迭代器失效的地方,返回新的迭代器來(lái)解決迭代器失效。


到此這篇關(guān)于c++中vector的使用和模擬實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)c++ vector使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言的數(shù)字游戲算法效率問(wèn)題探討實(shí)例
這篇文章主要介紹了C語(yǔ)言的數(shù)字游戲算法效率問(wèn)題探討實(shí)例,需要的朋友可以參考下2014-04-04
關(guān)于c語(yǔ)言逗號(hào)表達(dá)式的運(yùn)算規(guī)則知識(shí)點(diǎn)
在本篇文章里小編給大家整理的是關(guān)于c語(yǔ)言逗號(hào)表達(dá)式的運(yùn)算規(guī)則知識(shí)點(diǎn),需要的朋友們可以學(xué)習(xí)參考下。2020-03-03
C/C++可變參數(shù)函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了C/C++可變參數(shù)函數(shù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
C語(yǔ)言手把手教你實(shí)現(xiàn)貪吃蛇AI(中)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言手把手教你實(shí)現(xiàn)貪吃蛇AI的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Qt編寫(xiě)地圖之實(shí)現(xiàn)覆蓋物坐標(biāo)和搜索
地圖應(yīng)用中經(jīng)常會(huì)需要有覆蓋物坐標(biāo)和搜索的功能,本文將利用Qt實(shí)現(xiàn)這一功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-03-03

