[C++标准模板库:自修教程与参考手册]关于vector
什么是vector
可以这样认为,vector就是一个动态的数组,其中的元素必须具备assignable(可赋值)和copyable(可拷贝)两个性质。
vector的一些重要的性质
- vector支持随机存取,存取时间为O(1)。
- vector的迭代器是随机存取迭代器,所以所有的STL算法都可以使用。
- 在末尾添加元素时,vector的性能非常好(只要总的元素个数没超过capacity就行)。但是如果在中间或者前面插入元素,那么性能就不是那么好了,此元素的后面全部元素都要后移,即每一次移动都要执行assign赋值操作。
- 两个vector交换内容后,它们的容量也会交换。
- vector的第一个元素的索引为0,最后一个元素的索引为size()-1。
- 一个vector vec,它的一些操作:vec[x],vec.front(),vec.back()三个操作都不会检查元素是否存在,所以要我们自己进行判断该位置的元素存在与否。
vector的内存分配
vector的size表示当前拥有元素的个数,capacity表示vector最多能拥有多少个元素。如果size的大小超过了capacity,那么vector就会重新调用内存分配器分配新的内存。
vector的容量之所以有很大的重要性,是因为两个原因:
- 一旦内存重新分配,那么这个vetor的迭代器,引用,指针全都会失效。
- 内存重新分配非常耗费时间。
当然,也可以使用reserve()函数来保存适当的容量,避免不必要的内存配置:
std::vector<int> v;
//提前分配好100的容量
v.reserve(100);
当然,如果reserve()的参数中的数值比当前的capacity要小的话,那么不会有任何反应。
vector一些常用函数
std::vector<int> c;
//返回idx位置所在的元素,如果月结,就会跑出out_of_range异常
c.at(idx);
//返回索引idx所在的元素,不进行范围检查
c[idx];
//返回第一个元素。不检查第一个元素是否存在
c.front();
//返回最后一个元素,不检查最后一个元素是否存在
c.back();
//返回一个随机存取迭代器,指向第一个元素
c.begin();
//返回一个随机存取迭代器,指向最后一个元素
c.end();
//返回一个逆向迭代器,指向逆向迭代的第一元素
c.rbegin();
//返回一个逆向迭代器,指向逆向迭代的最后元素的下一个位置
c.rend();
//在pos位置上插入一个elem副本,并返回新元素的位置
c.insert(pos,elem);
//在pos位置上插入n个elem副本,无返回值。
c.insert(pos,n,elem);
//在pos位置上插入区间[beg:end]内所有元素的副本,无返回值
c.insert(pos,beg,end);
//在尾部添加一个elem副本
c.push_back();
//移除最后一个元素,但是不传回
c.pop_back();
//移除pos位置上的元素,返回下一个元素的位置
c.erase(pos);
//移除[beg,end]区间内的所有元素,返回下一元素的位置
c.erase(beg,end);
//将元素数量改为num,如果size()变大了,多出来的新元素都用默认构造函数完成
c.resize(num);
//将元素熟练改为num,如果size()变大了,多出来的新元素都是elem的副本
c.resize(num,elem);
//移除所有的元素,将容器清空
c.clear();
[C++标准模板库:自修教程与参考手册]关于vector的更多相关文章
- [C++标准模板库:自修教程与参考手册]关于deque
Deque的基本概念 deque和vector很相似,也提供随机存取的能力,将元素都动态地存储在一个数组中,最大的区别就是:deque的头和尾都是开放的,非常方便在头尾两端进行一些操作.(重点在于:d ...
- [C++标准模板库:自修教程与参考手册]关于auto_ptr
什么是auto_ptr指针 auto_ptr是这样一种指针:它是"它所指的对象"的拥有者,所以,当身为对象拥有者的auto_ptr指针被摧毁时,该对象也会被摧毁,auto_ptr要 ...
- STL 简介,标准模板库
这篇文章是关于C++语言的一个新的扩展--标准模板库的(Standard Template Library),也叫STL. 当我第一次打算写一篇关于STL的文章的时候,我不得不承认我当时低估了这个话 ...
- c++学习书籍推荐《数据结构C++语言描述:应用标准模板库STL(第2版)》下载
本书是Ford和Topp两位教授于1996看出版的名著Data Structures with C++的第2版,在全球范围内已经有数以万计的学生从中受益.作者将C++语言作为算法描述语言,应用包含规范 ...
- 7.4 C++标准模板库(STL)的概念
参考:http://www.weixueyuan.net/view/6401.html 总结: 标准模板库为C++提供了完善的数据结构及算法. 标准模板库包括三部分:容器.算法和迭代器. 容器是对象 ...
- 如何导出标准模板库(STL)类的实例化和包含STL类对象数据成员的类
本文翻译自 https://support.microsoft.com/zh-cn/help/168958/how-to-export-an-instantiation-of-a-standard-t ...
- C++标准模板库(STL)和容器
1.什么是标准模板库(STL)? (1)C++标准模板库与C++标准库的关系 C++标准模板库其实属于C++标准库的一部分,C++标准模板库主要是定义了标准模板的定义与声明,而这些模板主要都是 类模板 ...
- 标准模板库(STL)学习指南之sort排序
对于程序员来说,数据结构是必修的一门课.从查找到排序,从链表到二叉树,几乎所有的算法和原理都需要理解,理解不了也要死记硬背下来.幸运的是这些理论都已经比较成熟,算法也基本固定下来,不需要你再去花费心思 ...
- C++标准模板库Stand Template Library(STL)简介与STL string类
参考<21天学通C++>第15和16章节,在对宏和模板学习之后,开启对C++实现的标准模板类STL进行简介,同时介绍简单的string类.虽然前面对于vector.deque.list等进 ...
随机推荐
- 【算法】基础DP
参考资料 背包九讲 一.线性DP 如果现在在状态 i 下,它上一步可能的状态是什么. 上一步不同的状态依赖于什么. 根据上面的分析,分析出状态和转移方程.注意:dp 不一定只有两维或者一维,一开始设计 ...
- Dapr v1.9.0 版本已发布
Dapr是一套开源.可移植的事件驱动型运行时,允许开发人员轻松立足云端与边缘位置运行弹性.微服务.无状态以及有状态等应用程序类型.Dapr能够确保开发人员专注于编写业务逻辑,而不必分神于解决分布式系统 ...
- 2022年最新最详细在IDEA中配置Tomcat(含有详细图解过程)、建立使用IEDA建立一个Web项目的案例
1.首先已经成功安装过tomcat 如果没有成功安装,参考这篇tomcat安装教程(安装成功可忽略):https://blog.csdn.net/weixin_43304253/article/det ...
- flutter系列之:flutter中可以建索引的栈布局IndexedStack
目录 简介 IndexedStack简介 IndexedStack的使用 总结 简介 之前我们介绍了一个flutter的栈结构的layout组件叫做Stack,通过Stack我们可以将一些widget ...
- P 算法与 K 算法
P 算法与 K 算法 作者:Grey 原文地址: 博客园:P 算法与 K 算法 CSDN:P 算法与 K 算法 说明 P 算法和 K 算法主要用来解决最小生成树问题,即:不破坏连通性删掉某些边,使得整 ...
- day09-Tomcat01
Tomcat01 1.WEB开发介绍 WEB,在英文中WEB表示网/网络资源,它用于表示WEB服务器(主机)供浏览器访问的资源 WEB服务器(主机)上供外界访问的Web资源为: 静态web资源(如ht ...
- Codeforces Round #812 (Div. 2) D. Tournament Countdown(交互题)
记录一下第一次写交互题 题目大意:一共有1<<n个人参加一场竞标赛,需要你通过比较两人的胜场来判断谁晋级,最终获得第一名 最多1/3*2^(n+1)次询问,每次询问query(a,b),如 ...
- Pytest学习
pytest简介 pytest是python的一种单元测试框架,与python自带的unittest测试框架类似,但是比unittest框架使用起来更简洁,效率更高. 使用介绍 编写规则 测试函数以t ...
- .NET7 一个实用功能-中央包管理
依赖管理是 NuGet 的核心功能.Nuget管理单个项目的依赖关系很容易.管理多项目解决方案的依赖关系可能会变得很困难,因为它们的规模和复杂性开始扩大. 在您管理许多不同项目的公共依赖项的情况下,您 ...
- 嵌入式-C语言基础:二级指针
二级指针:可以理解为指向指针的指针,存放的是指针变量的地址. 下面用一级指针来保存一个指针变量的地址: #include<stdio.h> int main() { int *p1; in ...