首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

vector不是模板_vector实现

1.vector容器 vetcor顾名思义就是一个向量的容器,该容器中的每个元素都属于同一个类型,有点类似于数组,vetor容器与数组的不同之处就在于,它具有“动态”的属性,举例来说,如果定义了一个vector...vector容器的常规操作有: 初始化 vectora(10) vector :说明这是一个什么容器 int : 说明这个容器里面放的是什么类型的东西 a: 容器名 (10); 这个容器有多大...vectora(10,995) //这个容器一共有10元素,每个元素的值都是998 访问vector 下标 at方法 其他 a[10] //访问第11个元素 a.at(4) //访问第...5个元素 a.back(); //返回a的最后一个元素 a.front(); //返回a的第一个元素 遍历vector中的元素 迭代器 for(auto it = a.begin(); it !...利用下标 for(auto i = 0; i < a.size(); ++i) cout<<a[i]<<" "; cout<<endl; 注意 .size()方法可以获取vector

62910
您找到你想要的搜索结果了吗?
是的
没有找到

【c++】vector以及vector的模拟实现

vector的介绍及使用 1.vector的介绍 https://cplusplus.com/reference/vector/vector/ vector是表示可变大小数组的序列容器 就像数组一样,.../reference/vector/vector/ vector在实际中非常的重要,在实际中我们熟悉常见的接口就可以,下面列出了哪些接口是要重点掌握的 2.1 vector的定义 2.2 vector...深度剖析及模拟实现 3.1 使用memcpy拷贝问题 假设模拟实现vector中的reserve接口中,使用memcpy进行的拷贝,以下代码会发生什么问题?...(size_t n) { // 使用vector定义二维数组vv,vv中的每个元素都是vectorvector> vv(n); // 将二维数组每一行中的vecotr...类型的,每行没有包含任何元素,如果n为5时如下所示: vv中元素填充完成之后,如下图所示: 使用标准库中vector构建动态二维数组时与上 3.3 代码实现 由于vector实例化的时候需要类型,所以在命名空间中用类模板进行实现

5510

vector的模拟实现

上一篇我们对vector一些常用的函数进行了讲解,本篇博客我们就对vector进行模拟实现,以便于我们更好地了解vector的使用以及对一些常见bug的认识 有了string类的模拟实现vector的模拟实现我们上手起来就简单一点了...: 首先为了和库里面的vector混淆视听,放入自己命名的空间里,并且根据vector的源码分析我们得出了三个成员变量: 分别是: 其实他们实质上都是指针,位置大概是这样的,遵循左闭右开的规则...size_t size() const { return _finish - _start; } pushback尾插函数 尾插函数在很多地方可以复用,所以我们首先解决了尾插,为后面的函数进行模拟实现提供了基础...pos) const { assert(pos < size()); return _start[pos]; } resize函数和reserve函数 其实我们可以将reserve先实现后直接将..._start = tmp; _finish = _start + sz; _endofstorage = _start + n; } } resize函数的扩容我们就用reserve来实现

7110

【C++】模拟实现vector

一.了解项目功能 声明: 该模拟实现仅适用于STL初学小白了解vector的简单实现,会结合一些STL源码作为参照,但是源码中涉及的空间配置器部分我们不做涉及!...spm=1001.2014.3001.5502 二.逐步实现项目功能模块及其逻辑详解 通过第一部分对项目功能的介绍,我们已经对vector的功能有了大致的了解,虽然看似需要实现的功能很多...vector构造函数 实现无参构造函数 vector的无参构造函数比较简单,我们利用初始化列表将所有的迭代器都指向nullptr即可,无参构造函数代码如下: vector() :_start...& operator=(vector v) { swap(v); return *this; } 实现vector的begin()函数和end()函数 因为我们实现vector...修改容量前后,vector在内存中的情况图示如下: 综上所述,reserve()函数实现代码如下(该实现包含两大陷阱错误): void reserve(size_t n) { //检查

5020

【STL】vector的模拟实现

放在专栏【C++知识总结】,会持续更新,期待支持 1、vector的数据结构 这里我们与SGI版本保持一致,成员变量为三个迭代器,对一些常见接口实现模拟。...2.1.5、析构 析构函数的实现很简单,直接delete后,将迭代器置空即可: 2.2、迭代器相关 对于vector中的begin,返回其首地址即start,end返回finish即可。  ...我们知道,迭代器最重要的就是要实现对容器元素的访问,因此迭代器的++与解引用*操作十分重要,但是由于vector的迭代器是一个指针,而我们知道,指针本身就支持++与解引用操作,并且我们这里vector是一个连续的空间...,指针++会跳过一个T类型的大小,即会指向vector 中的下一个元素,因此这里我们不需要手动实现(指针本身自带)。...2.3、运算符重载 2.3.1、[]重载 我们知道vector是可以用下标来实现对元素的访问,这里我们对[]进行重载,使我们的vector也支持下标访问。不过在实现时需要注意避免下标越界。

21230

C++初阶:适合新手的手撕vector(模拟实现vector

上次讲了常用的接口:C++初阶:容器(Containers)vector常用接口详解 今天就来进行模拟实现啦 1.基本结构与文件规划 vector.h头文件:包含类的全部(函数的声明与定义) test.cpp...在这个实现中,_finish 指针始终指向当前元素范围的末尾,也就是下一个要插入元素的位置。 _endOfStorage:指向动态数组分配的内存空间的末尾之后的位置的指针。...在这个实现中,_endOfStorage 指针指向当前分配的内存空间的末尾,当需要扩充容量时,会通过比较 _finish 和 _endOfStorage 的位置来判断是否需要重新分配更大的内存空间 2....capacity 函数: capacity 函数用于返回数组的容量,即 _endOfStorage 和 _start 之间的距离 怎么来理解:const T& x = T() 实现给出各种类型的默认值,...endl; v.erase(v.begin());//头删 for (auto e : v) { cout << e << " "; } cout << endl; } 5.在实现

30210

C++之模拟实现vector

前言 因为学习了vector的相关知识,了解了vector大部分接口的底层实现原理,所以我决定自己模拟实现一个mini版的vector类,用来加深对vector各方面知识的理解。...为了避免将用n个Int型元素构造一个vector型的对象的函数调用匹配到下面的用T类型的迭代器初始化vector型的对象的构造函数(会发生错误的间接寻址),我们就得重载一个用n个Int数据初始化vector...= last) { push_back(*first); first++; } } 2.拷贝构造 现代写法的优点在模拟实现string中已经介绍过,此处不再赘述。...(nullptr) { vector temp(v.begin(), v.end()); Swap(temp); } 自己实现的Swap可以避免深拷贝,提高效率 void...cout << vv[i][j] << " "; } cout << endl; } cout << endl; } 总结 以上就是今天要讲的内容,本文介绍了作者自己实现

31140

C++:Vector的模拟实现

Vector虽然也支持下标访问,但是很多成员函数都是用的迭代器,所以我们要模拟实现的话迭代器十分重要,vs使用的是PJ版的STL版本,比较难懂,所以我们模拟实现统一用SGI版本去实现,所以在模拟实现之前...通过这个我们可以观察到SGI版本下的迭代器其实就是一个原生指针,value_type*类型相当于是模板T对应的指针类型,有了这些大致了解,我们就可以去模拟实现啦!!...二,vector的模拟实现 大致框架需要有模板(类外定义)/迭代器以及迭代器的获取(public定义,要有可读可写的也要有可读不可写的)/成员变量(private定义)  并且为了不和库的vector...return _finish; } private: //成员变量 iterator _start; iterator _finish; iterator _end_of_storage; } } 然后我们开始实现...= last) { push_back(*first); ++first; } }  push_back是尾插数据,具体实现后面会写。

8510
领券