移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——6.vector(模拟实现)

2024-08-23 04:44

本文主要是介绍移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——6.vector(模拟实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.存储结构

namespace zone
{template<class T>   //需要模板class vector{public:private:iterator _start;iterator _finish;iterator _endofstorage;};
}

可见,vector内核是由三个指针实现的

2.默认成员函数 

2.1.构造函数

1.初始化列表

vector()
:_start(nullptr)
, _finish(nullptr)
, _endofstorage(nullptr){}

2.拷贝构造

//v1(v2)
vector(const vector<T>& t)      :_start(nullptr), _finish(nullptr), _endofstorage(nullptr)
{for (auto& arr : t){push_back(arr);}
}// v1=v2
void swap( vector<T>& t)//swap要求参数是&,且不带const
{std::swap(_start, t._start);std::swap(_finish, t._finish);std::swap(_endofstorage, t._endofstorage);
}vector<T>& operator=(vector<T> t) // 这里不能用const,因为要调用swap,如果是const会造成权限放大
{swap(t);return *this;
}

 3.迭代器区间构造

template <class InputIterator>     //在类模板中再次使用模板
vector(InputIterator first, InputIterator last)
{while (first != last)          //记得是!=  不能写成<=,因为存储空间不一定连续!!!!!{push_back(*first);first++;}
}                   //可以使用别的类型的迭代器区间去初始化vector,不一定要用vector<T>类型

2.2.析构函数 

 

~vector()
{delete[] _start;_start = _finish = _endofstorage = nullptr;
}

 3.容量操作函数

3.1.reserve(设置空间大小)

 

void reserve(size_t n)
{if (n > capacity()){T* tmp = new T[n];size_t sz = size();if (_start){//memcpy(tmp, _start, sizeof(T) * sz);     //若类型为string,memcpy会调用浅拷贝,_start和tmp指向同一块空间,然后delete对于自定义类型调用析构函数,销毁空间for (size_t i = 0; i < sz; i++){tmp[i] = _start[i];          //若为string类型,相当于s1=s2;赋值,会调用拷贝构造,深拷贝}delete[]_start;}_start = tmp;_finish = _start + sz;_endofstorage = _start + n;}}

3.2  resize(重新设置vector的长度)

 

void resize(size_t n, const T& val = T())     //若大于容量则扩容,并用val来填充扩容  //表达式会产生临时变量(!!!),有常性,需要用const &或者不用&
{if (n <= size()){_finish = _start + n;    //缩容}else{reserve(n);while (_finish < _start + n){*_finish = val;++_finish;}}}

3.3 获取size和capacity

size_t size() const
{return _finish - _start;
}size_t capacity() const
{return _endofstorage - _start;
}

4.访问函数 

4.1[]

T& operator[](size_t pos){assert(pos < size());return _start[pos];}

 4.2 迭代器

typedef T* iterator;typedef  const T* const_iterator;iterator begin()
{return _start;
}iterator end()
{return _finish;
}const_iterator begin()const
{return _start;
}const_iterator end()const
{return _finish;
}

5.插入类函数 

5.1insert

void insert(iterator pos, const T& x)       //在pos位置插入x,
{assert(pos >= _start);assert(pos <= _finish);if (_finish == _endofstorage){size_t len = pos - _start;reserve(capacity() == 0 ? 4 : capacity() * 2);pos = _start + len;//扩容会导致原空间被删除,如果没有len记录长度并重新赋值pos,会导致pos失效(pos依旧指向被删除空间的某个位置而不是新空间的某个位置)}iterator end = _finish - 1;while (end >= pos){*(end + 1) = *end;end--;}*pos = x;_finish++;
}

5.2 push_back 

void push_back(const T& x)
{insert(_finish, x);
}

6.删除类函数(erase)

 

iterator erase(iterator pos)
{assert(pos >= _start);assert(pos <= _finish);iterator it = pos + 1;while (it < _finish){*(it - 1) = *it;it++;}_finish--;return pos;
}

这篇关于移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——6.vector(模拟实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1098384

相关文章

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

C#实现文件读写到SQLite数据库

《C#实现文件读写到SQLite数据库》这篇文章主要为大家详细介绍了使用C#将文件读写到SQLite数据库的几种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录1. 使用 BLOB 存储文件2. 存储文件路径3. 分块存储文件《文件读写到SQLite数据库China编程的方法》博客中,介绍了文

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主