STL之序列容器vector
首先来看看vector的模板声明:
template <class T, class Alloc = allocator<T>> class vector { //… };
vector接受2个模板参数,其中分配器属于默认参数,当然如果你想使用其他分配器话,得把2个参数都写出来,一般只需写入元素类型即可进行vector模板的实例化,如:
vector<int> vec;
vector属于序列式容器。所谓序列式容器,其中的元素都可序,但未必有序。vector与array其实挺像的, 唯一的区别就是array是静态空间,一旦配置了就不能改变。而vector呢,如果分配的空间不足,将会重新配置一块新空间,大小是原空间的2倍,然后将元素一一搬过来,最后释放旧空间。因此,vector比array更灵活。示意图如下:
(图片来自侯捷老师课程《STL与泛型编程》, 侵删)
(重新分配新空间 ,元素转移,释放旧内存)
顺便提一下vector的迭代器:vector的迭代器其实就是普通指针,由于vector具有连续的地址空间,所以它的迭代器类型支持Random Access iterators,随机存取,可跳跃。由于它的迭代器特性,使得vector中元素如果要实现某些算法时效率极高,如二分搜索系列算法。
vector常用的元素操作:push_back, pop_back, erase, insert, clear等。我们主要谈谈erase.
erase算法有两个版本:
iterator erase(iterator first, iterator last); // 清除[first, last)中的所有元素 iterator erase(iterator position); // 清除某个位置上的元素
附一段测试代码(版本为Dev C++5.11):
#include <iostream> #include <vector> #include <algorithm> using namespace std; int main() { int i; vector<, ); cout << "size = " << iv.size() << endl; // size = 2 cout << "capacity = " << iv.capacity() << endl; // capacity = 2 iv.push_back(); cout << "size = " << iv.size() << endl; // size = 3 cout << "capacity = " << iv.capacity() << endl; // capacity = 4 iv.push_back(); cout << "size = " << iv.size() << endl; // size = 4 cout << "capacity = " << iv.capacity() << endl; // capacity = 4 iv.push_back(); cout << "size = " << iv.size() << endl; // size = 5 cout << "capacity = " << iv.capacity() << endl; // capacity = 8 iv.push_back(); cout << "size = " << iv.size() << endl; // size = 6 cout << "capacity = " << iv.capacity() << endl; // capacity = 8 ; i < iv.size(); i++) { // 9 9 1 2 3 4 cout << iv[i] << ' '; } cout << endl; iv.push_back(); cout << "size = " << iv.size() << endl; // size = 7 cout << "capacity = " << iv.capacity() << endl; // capacity = 8 ; i < iv.size(); i++) { // 9 9 1 2 3 4 5 cout << iv[i] << ' '; } cout << endl; vector<); if (ivite != iv.end()){ iv.erase(ivite); } cout << "size = " << iv.size() << endl; // size = 6 cout << "capacity = " << iv.capacity() << endl; // capacity = 8 ; i < iv.size(); i++) { // 9 1 2 3 4 5 cout << iv[i] << ' '; } cout << endl; ivite = find(iv.begin(), iv.end(), ); if (ivite != iv.end()){ iv.insert(ivite, 1, ); // insert算法内部实现比较复杂(不做详谈)如:当备用空间不足,配置新内存的长度 } // 旧长度的2倍,或是旧长度+新增元素个数 cout << "size = " << iv.size() << endl; // size = 7 cout << "capacity = " << iv.capacity() << endl; // capacity = 8 ; i < iv.size(); i++) { cout << iv[i] << ' '; // 9 1 7 2 3 4 5 } cout << endl; iv.clear(); cout << "size = " << iv.size() << endl; // size = 0 cout << "capacity = " << iv.capacity() << endl; // capacitu = 8 return 0; }
STL之序列容器vector的更多相关文章
- C++线性序列容器<vector>简单总结
C++线性序列容器<vector>简单总结 vector是一个长度可变的数组,使用的时候无须声明上限,随着元素的增加,Vector的长度会自动增加:Vector类提供额外的方法来增加.删除 ...
- STL常用序列容器
这里简要的记述一下STL常用容器的实现原理,要点等内容. vector vector是比较常用的stl容器,用法与数组是非类似,其内部实现是连续空间分配,与数组的不同之处在于可弹性增加空间,而arra ...
- STL标准库-容器-vector
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. 向量容器vector是一个动态数组,内存连续,它是动态分配内存,且每次扩张的原来的二倍. 他的结构如下 一 定义 vector ...
- STL之序列容器deque
首先看看deque的模板声明: template <class T, class Alloc = allocator<T>> // 原本还有个参数BufSize,现在新版本 ...
- C++STL(二)——vector容器
STL--vector容器 vector对象的概念 vector基本操作 vector对象的初始化.赋值 vector查找.替换(已在上一片 string类 博客总结过了,不再总结) vector添加 ...
- C++中防止STL中迭代器失效——map/set等关联容器——vector/list/deque等序列容器—如何防止迭代器失效—即erase()的使用
序列性容器::(vector和list和deque) erase迭代器不仅使所有指向被删元素的迭代器失效,而且使被 删元素之后的所有迭代器失效,所以不能使用erase(iter++)的方 式, ...
- C++进阶 STL(1) 第一天 [容器,算法,迭代器] string容器 vector容器 deque容器
课程大纲 02实现基本原理 容器,算法,迭代器 教室:容器 人:元素 教室对于楼:容器 序列式容器: 容器元素在容器中的位置是由进入容器的时间和地点来决定 序列式容器 关联式容器: 教室中 按年龄排座 ...
- 《STL源码剖析》——第四章、序列容器
1.容器的概观与分类 所谓序列式容器,其中的元素都可序(ordered)[比如可以使用sort进行排序],但未必有序(sorted).C++语言本身提供了一个序列式容器array,STL另外再提供v ...
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
随机推荐
- python2 与 python3 urllib的互相对应关系
urllib Python2 name Python3 nameurllib.urlopen() Deprecated. See urllib.request.urlopen() which mirr ...
- Python 定位字符串
一位朋友在玩闯关游戏时遇到如下问题: 感觉考查的就是字符串操作,用string模块就可完成:代码如下: # -*- coding: utf-8 -*- __author__ = 'Evilxr' im ...
- 《java编程思想》读书笔记(二)第五章(2)
成员初始化 Java尽力保证:所有变量在使用前都能得到恰当的初始化. 对于方法的局部变量,Java会以编译时报错的形式贯彻这种保证,比如: void f() { int i; //这里编译时就会报错, ...
- malloc原理和内存碎片[转]
当一个进程发生缺页中断的时候,进程会陷入内核态,执行以下操作: 1.检查要访问的虚拟地址是否合法 2.查找/分配一个物理页 3.填充物理页内容(读取磁盘,或者直接置0,或者啥也不干) 4.建立映射关系 ...
- Servlet、JSP中页面跳转的方式
一.Servlet:当然,在servlet中,一般跳转都发生在doGet, doPost等方法里面.1) redirect 方式response.sendRedirect("success ...
- python海龟图制作
海龟画图很好看,先上图形: 依据代码注释随意打印出来就行: #!/usr/bin/python3.4 # -*- coding: utf-8 -*- import turtle # 拿起一支笔 t = ...
- backbone学习总结(一)
入职第三天,新公司项目用到backbone+underscore+require等框架,前两天把项目的开发环境都配置好啦,项目也能跑起来,现在准备好好学习公司自己的框架以及用到的框架,有点想吐槽,开发 ...
- Java创建树形结构算法实例
在JavaWeb的相关开发中经常会涉及到多级菜单的展示,为了方便菜单的管理需要使用数据库进行支持,本例采用相关算法讲数据库中的条形记录进行相关组装和排序讲菜单组装成树形结构. 首先是需要的JavaBe ...
- access生成sql脚本,通过VBA调用ADOX
access生成sql脚本,通过VBA调用ADOX. 使用 MS Access 2016 的VBA,读取mdb文件中的所有表结构(数据类型/长度/精度等),生成对应的SQL create table语 ...
- HTML 代码复用实践 (静态页面公共部分提取复用)
原文:HTML 代码复用实践 上面的链接里面安装配置步骤已经非常详细,这里主要记录我操作过程中遇到的几个问题 gulp-file-include 的使用 按上面的步骤安装之后,node_mod ...