<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
vector在實際中非常重要且使用,因此我們需要熟悉使用常用的介面,以下將從常用的介面入手並進行模擬實現
vector模擬實現的基本結構:
template<class T> class vector { public: typedef T* iterator; typedef const T* const_iterator; //無參構造 vector() :_start(nullptr) , _finish(nullptr) , _endofstoage(nullptr) {} //資源管理 ~vector() { if (_start) { delete[] _start; _start = _finish = _endofstoage = nullptr; } } size_t size() const{ return _finish - _start; } size_t capacity() const{ return _endofstoage - _start; } private: iterator _start; iterator _finish; iterator _endofstoage; };
建構函式宣告 constructor | 介面說明 |
vector()(重點) | 無參構造 |
vector (const vector& x); (重點) | 拷貝構造 |
vector(size_type n, const value_type& val = value_type()) | 構造並初始化n個val |
vector (InputIterator first, InputIterator last); | 使用迭代器進行初始化構造 |
//無參構造 vector() :_start(nullptr) , _finish(nullptr) , _endofstoage(nullptr) {} //拷貝構造 void swap(vector<T>& v){ std::swap(_start, v._start); std::swap(_finish, v._finish); std::swap(_endofstoage, v._endofstoage); } //vector(const vector& v) vector(const vector<T>& v) :_start(nullptr) , _finish(nullptr) , _endofstoage(nullptr) { vector tmp(v.begin(), v.end()); swap(tmp); } //初始化n個val vector(size_t n, const T& val = T()) :_start(nullptr) , _finish(nullptr) , _endofstoage(nullptr) { reserve(n); for (size_t i = 0; i < n; ++i) { push_back(val); } } //使用迭代化區間初始化 template <class InputIterator> vector(InputIterator first, InputIterator last) :_start(nullptr) , _finish(nullptr) , _endofstoage(nullptr) { while (first != last) { push_back(*first); ++first; } }
iterator的使用 | 介面說明 |
begin+end (重點) | 獲取第一個資料位置的iterator/const_iterator, 獲取最後一個資料的下一個位置
的iterator/const_iterator |
rbegin+rend(反向迭代器) | 獲取最後一個資料位置的reverse_iterator,獲取第一個資料前一個位置的
reverse_iterator |
iterator begin(){ return _start; } iterator end(){ return _finish; } const iterator begin() const{ return _start; } const iterator end() const{ return
容量空間 | 介面說明 |
size | 獲取資料個數 |
capacity | 獲取容量大小 |
empty | 判斷是否為空 |
resize(重點) | 改變vector的size |
reserve(重點) | 改變vector的capacity |
void resize(size_t{ if (n > capacity()) { reserve(n); } if (n > size()) { while (_finish < _start + n) { *_finish = val; ++_finish; } } else
void reserve(size_t{ size_t sz = size(); if (n > capacity()) { T* tmp = new T[n]; if (_start) { //這裡會造成淺拷貝問題 //memcpy(tmp, _start, size() * sizeof(T)); for (size_t i = 0; i < size(); ++i) { tmp[i] = _start[i]; } delete[] _start; } _start = tmp; } _finish = _start + sz; _endofstoage = _start + n; }
注意:
1、我們在擴容的時候有一個小細節,capacity的容量擴容在vs和g++下分別執行是有區別的,在Vs下caoacity的擴容是按1.5倍增長的;在g++下是按2倍增長的。不能固化的認為,vector的增長都是2倍,具體增長的多少要根據需求定義。Vs是PJ盤本的STL,g++是SGI版本的STL。
//vs下 int main(){ vector<int> v; size_t sz = v.capacity(); for (int i = 0; i < 100; ++i) { v.push_back(i); if (sz != v.capacity()) { sz = v.capacity(); cout << "capacity changed: " << sz << 'n'; } } return 0; }
vector增刪查改 | 介面說明 |
push_back(重點) | 尾插 |
pop_back (重點) | 尾刪 |
查詢。(注意這個是演演算法模組實現,不是vector的成員介面) | |
在pos之前插入val | |
刪除pos位置的資料 | |
交換兩個vector的資料空間 | |
operator[] (重點) | 像陣列一樣存取 |
void push_back(const{ if (_finish == _endofstoage) { size_t newCapacity = capacity() == 0 ? 4 : capacity() * 2; reserve(newCapacity); } *_finish = x; ++_finish; //insert(end(), x);
方法:
pop_back比較簡單,尾刪的邏輯不是刪除而是覆蓋,因此只需要--_finish即可
void pop_back(){ if (_finish > _start) { --_finish; } //erase(end() - 1);
insert插入是在pos位置之前插入x
方法:
由於迭代器失效問題比較複雜,情況多樣,我總結了一篇單獨的部落格供大家參考:
iterator insert(iterator pos, const{ //檢查 assert(pos >= _start && pos <= _finish); //空間不夠 擴容 //擴容以後 pos就失效了 if (_finish == _endofstoage) { //使用相對距離來計算確定pos位置 size_t n = pos - _start; size_t newCapacity = capacity() == 0 ? 4 : capacity() * 2; reserve(newCapacity); pos = _start + n; } //挪動資料 iterator end = _finish - 1; while (end >= pos) { *(end + 1) = *end; --end; } *pos = x; ++_finish; return
erase是刪除pos位置的資料
方法:
iterator erase(iterator pos){ assert(pos >= _start && pos <= _finish); iterator it = pos + 1; while (it != _finish) { *(it - 1) = *it; ++it; } --_finish; return
過載的operator [ ] 就是取到pos位置對應的資料即可,比較簡單
operator[](size_t pos) { assert(pos < size()); return _start[pos]; } const T& operator[](size_t pos) const { assert(pos < size()); return
到此這篇關於C++ STL _ Vector使用及模擬實現的文章就介紹到這了,更多相關C++ STL _ Vector使用 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45