STL学习系列之二——序列容器(vector)
来源:互联网 发布:新开淘宝每天流量100人 编辑:程序博客网 时间:2024/06/05 01:00
STL学习之二 序列容器(vector)
一、C++标准模板库提供了三种序列容器:vector、list、deque。类模板vector和deque都以数组为基础,类模板list实现了链表的数据结构。
STL中最流行的是类模板vector,它是一种更健壮的数据类型,相当于动态数组,能动态得改变数组的大小。
Vector和C和C++的原始数组不同。为什么不同呢?因为vector能够彼此赋值,基于指针的C风格的数组不支持这种用法,为什么呢?因为这些数组的名称是常量指针,不能作为赋值的目标。就像C数组一样,vector的下标并不执行自动范围检查,但模板vector通过at成员函数可以对数组下标范围进行检查,待会在例子中将会看到。呵呵
vector、list、deque各有各的高效使用范围:
vector用于在容器的后端高效的的插入,在中间插入和删除元素的效率很低;
list用于经常在容器的中间位置和两个端点进行插入和删除;
deque经常用于对容器的两端进行高效的插入和删除;
1、 vector序列容器
类模板vector提供的数据结构,具有连续的内存位置,这样,就能够通过下标运算符[]高效而直接的访问vector中的任何一个元素,就像C和C++的原始数组一样。
当vector的内存耗尽的时候,它会分配一块更大的连续内存区域,将原来的元素复制到心得内存中并销毁旧的内存。
下面将介绍使用vector和迭代器,直接上demo
输出结果为:
初始化数组大小是:0
初始化数组容量是:0
数组大小是:3
数组容量是:3
用指针输出数组:1 2 3 4 5 6
用迭代器输出vector:2 3 4
翻转vector中的元素:4 3 2
注:迭代器的行为就像指向元素的指针一样,它重载了运算符*,返回指向这个元素的引用。
操作vector元素的函数
直接上demo
输出结果为:
Vector元素包括:1 2 3 4 5 6
第一个元素是:1
最后一个元素是:6
改变后vector元素的内容为:7 22 2 10 4 5 6
Exception:invalid vector<T> subscript
清除第一个元素后为:22 2 10 4 5 6
清除所有的元素后,vector的元素isempty
清除前的内容:1 2 3 4 5 6
清楚后,vector isempty
注:front函数和begin函数的区别:front函数返回vector中第一个元素的引用,而begin函数返回一个随机访问迭代器,指向vector中的第一个元素;
back函数和end函数的区别:back函数返回vector中最后一个元素的引用,而end函数返回一个随机访问迭代器,指向vector的末尾;
- STL学习系列之二——序列容器(vector)
- STL学习系列之二——序列容器(vector)
- stl之序列容器——vector
- STL源码笔记(9)—序列式容器之vector(二)
- 《STL源码剖析》学习笔记之三——序列式容器(list和vector)
- STL学习系列之三——list序列容器
- STL学习系列之四——deque序列容器
- C++学习笔记——STL(二)vector容器
- STL学习笔记之 (二)容器 vector
- STL学习笔记之容器--vector(二)源码剖析
- STL源码剖析——序列容器之vector
- STL源码剖析——序列容器之vector
- STL 序列容器之vector
- STL序列容器之vector
- C++ STL学习之二:序列式容器vector深入学习
- STL系列之vector(容器)
- STL学习(二)--vector容器
- STL学习笔记--4、序列式容器之vector
- 从零开始写设备树DTS
- fedora(linux)创建系统服务 程序开机自启 后台运行
- opengles法线贴图
- ORCAD导出文件【PDF原理图】
- CAS实现单点登录(SSO)过程浅析
- STL学习系列之二——序列容器(vector)
- ps -aux详细解释
- MySQL的if,case语句使用总结
- HDU1521
- MySql建表时出错ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that correspond
- AI的胜利,人类的荣耀
- mysql 数据语句
- core核心模块—基本绘图
- 121. Best Time to Buy and Sell Stock