STL源代码学习--vector用法汇总
一、容器vector
使用vector你必须包含头文件<vector>:
#include<vector>
型别vector是一个定义于namespace std内的template:
- template<class _Ty,
- class _Ax = allocator<_Ty> >
第二个參数定义内存模型。
我们一般採用默认的内存模型。
二、vector的功能
vector模塑出一个动态数组。vector将其元拷贝到内部的动态数组中。
元素之间总是存在某种顺序,它是一种有序群集。
支持随即存取。
它的迭代器是随机存取迭代器。所以对不论什么一个STL算法都奏效。
向vector加入一个元素或者删除当中的一个元素,其后的全部元素都要移动位置,每一次移动都要调用赋值操作符。
所以。在末端加入或删除元素,性能非常好。
可是在前段或者中部的话。性能较差。
vector优异性能的秘诀之中的一个是它配置比其所容纳的元素所需很多其它的内存。我们须要了解大小和容量的关系。
函数size()能够返回vector的大小。即vector中实际元素的个数。
而capacity()返回容量。是当前的vector所实际可以容纳的元素的数量。它应该总是大于或者等于vector的大小。
假设须要向vector中放置比capacity很多其它的元素。则须要又一次配置内部存储器。
vector的容量也会随之增长。
看以下的演示样例代码:
- #include <iostream>
- #include <vector>
- #include <string>
- #include <algorithm>
- using namespace std;
- int main()
- {
- vector<string> sentence(1);
- cout << "max_size():" << sentence.max_size() << endl;
- cout << "size():" << sentence.size() << endl;
- cout << "capacity():" << sentence.capacity() << endl;
- sentence.reserve(5);
- sentence.push_back("Hello,");
- sentence.push_back("how ");
- sentence.push_back("are ");
- sentence.push_back("you ");
- sentence.push_back("?");
- copy(sentence.begin(),sentence.end(),
- ostream_iterator<string>(cout," "));
- cout << endl;
- cout << "max_size():" << sentence.max_size() << endl;
- cout << "size():" << sentence.size() << endl;
- cout << "capacity():" << sentence.capacity() << endl;
- swap(sentence[1],sentence[3]);
- sentence.insert(find(sentence.begin(),sentence.end(),"?"),
- "always");
- sentence.back() = "!";
- copy(sentence.begin(),sentence.end(),
- ostream_iterator<string>(cout," "));
- cout << endl;
- cout << "max_size():" << sentence.max_size() << endl;
- cout << "size():" << sentence.size() << endl;
- cout << "capacity():" << sentence.capacity() << endl;
- }
执行结果:

在程序中。当再次向vector插入元素时。因为vector的容量不够,所以引起了内存的又一次分配。可是capacity()的结果与实作版本号有关,max_size也是。
vector的容量十分重要,是由于:
1、一旦内存又一次配置,与之相关的全部的reference、pointers、iterators都会失效。
2、内存配置非常费时。
解决问题的方法有:
1、能够使用reserve()保留适当容量,降低又一次配置内存的次数。演示样例代码:
- vector<string> sentence(1);
- sentence.reserve(50);
2、在初始化期间向构造函数传递附加參数。构造出足够的空间。
- vector<T> v(5);
当然,这样的元素的型别必须提供默认构造函数。可是假设元素的型别比較复杂,初始化操作也非常耗时。
假设仅仅是为了保留足够的内存。用法1较好。
注意:reserve不能缩减vector的容量。由此,我们能够知道。即使删除元素。其reference、pointers、iterators也会继续有效,指向动作发生前的位置。
可是插入操作可能使reference、pointers、iterators失效(由于可能会导致又一次配置空间)。
使用swap函数能够缩减vector容量。
由于两个vector交换内容后,他们的容量也会互换。
1、
- template<class T>
- void shrinkCapacity(vector<T> &v)
- {
- vector<T> tmp(v);
- v.swap(tmp);
- }
2、
- vector<T>(v).swap(v);
上面两种方法等价。
都是先构造出一个暂时vector对象,以v的元素进行初始化,再与v进行交换。
须要注意的是:暂时对象一般都是精确分配实际所需的内存。
所以可以起到减小vector容量的效果。
三、vector的操作函数
全部的构造函数和析构函数例如以下:

非变动性操作:

赋值操作:

上述操作进行的是将新元素赋值给vector,并将旧元素所有移除!演示样例代码:
- #include <iostream>
- #include <vector>
- #include <string>
- #include <algorithm>
- using namespace std;
- int main()
- {
- vector<string> sentence(1);
- cout << "max_size():" << sentence.max_size() << endl;
- cout << "size():" << sentence.size() << endl;
- cout << "capacity():" << sentence.capacity() << endl;
- sentence.reserve(5);
- sentence.push_back("Hello,");
- sentence.push_back("how ");
- sentence.push_back("are ");
- sentence.push_back("you ");
- sentence.push_back("?
");
- copy(sentence.begin(),sentence.end(),
- ostream_iterator<string>(cout," "));
- cout << endl;
- sentence.assign(3,"new");
- copy(sentence.begin(),sentence.end(),
- ostream_iterator<string>(cout," "));
- cout << endl;
- }
执行结果:

能够看出原来的元素所有被删除了。
元素存取

在这几个函数中,唯一进行下标检查的是at函数。
因此。在调用operator[]的时候,必须心理清楚索引是否是有效的。
迭代器相关函数

迭代器失效的两种情况是:
1、在一个较小的位置上删除或者是移动元素。
2、因为容量的变换引起内存又一次分配。
插入和移除元素

插入和移除元素。都会使“作用点”之后的各元素的reference、pointers、iterators失效。插入操作还可能引发内存又一次分配,那么该容器上的全部的reference、pointers、iterators都会失效。
四、把vector当做一般数组使用
如今的C++标准保证vector的元素必须分布于连续空间中。对于vector中的一个合法索引,满足下列表达式:
&v[i] = &v[0] + i;
我们必须保证vector可以容纳全部数据。
假设使用的是C-String,记住最后有个'\0'。
仅仅要我们须要一个元素型别为T的数组,就能够採用vector<T>,然后传递第一个元素的地址给它。
注意:千万不要把迭代器当做第一元素的地址来传递。由于vector迭代器是由实作版本号定义的,不一定是一个一般指针。
- printf("%s",v.begin());//ERROR(might work,but not portable)
- printf("%s",&v[0]);//OK
STL源代码学习--vector用法汇总的更多相关文章
- STL源代码学习(vector篇)
#include <concept_checks.h> #include<stl_allocate.h> /// The vector base class's constru ...
- C++ STL源代码学习(map,set内部heap篇)
stl_heap.h ///STL中使用的是大顶堆 /// Heap-manipulation functions: push_heap, pop_heap, make_heap, sort_heap ...
- C++ STL源代码学习之算法篇
///因为篇幅太长,因此,删去了非常多接口,仅仅分析了内部实现,算法对迭代器的要求也被删去 /// search. template <class _ForwardIter1, class _F ...
- C++ STL常用容器基本用法汇总
1.vector 包含头文件#include<vector> 使用命名域using namespace std 定义元素类型为T的vector vector<T> vec 增: ...
- C++ STL源代码学习(list篇)
///STL list为双向循环链表 struct _List_node_base { _List_node_base* _M_next; _List_node_base* _M_prev; }; t ...
- C++ STL 源代码学习(之deque篇)
stl_deque.h /** Class invariants: * For any nonsingular iterator i: * i.node is the address of an el ...
- C++STL源代码学习(之slist篇)
///stl_slist.h ///list为双向循环链表,slist为单向链表.某些操作效率更高 ///slist是SGI额外提供的单向链表,不属于C++标准 struct _Slist_node_ ...
- STL vector用法介绍
STL vector用法介绍 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和f ...
- STL中的Vector相关用法
STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int> ...
随机推荐
- 1.namesapce用法
namespace用法示例 #include <iostream> using namespace std; //定义域名空间 namespace myspace { ; void sho ...
- 开发板 Linux驱动视频 驱动是什么
内存管理单元很重要. linux把设备看成文件,(open,read,write,ioctrl,close)主要写这几个函数. 哈弗结构,取指令和取数据同时进行. arm处理器体系架构以及发展方向 单 ...
- ThinkPHP5.0---删除数据
删除特定记录 public function delete() { // 获取要删除的对象:关键字为16 $Teacher = Teacher::); // 删除对象 $Teacher->del ...
- c#中反射的用法(即如何根据字符找到已定义的变量)
2013-07-20 08:06 720人阅读 评论(0) 收藏 举报 分类: C#(9) 作者同类文章 X 版权声明:本文为博主原创文章,未经博主允许不得转载. 常常羡慕javascript中, ...
- 深度解析VC中的消息
消息是指什么? 消息系统对于一个win32程序来说十分重要,它是一个程序运行的动力源泉.一个消息,是系统定义的一个32位的值,他唯一的定义了一个事件,向Windows发出一个通知,告诉应用程序某个事情 ...
- JPA 对象关系映射总结(一)---persistence.xml 文件配置要点
1. <property name="hibernate.hbm2ddl.auto" value="update"/>,这里表示的 功能是: 自动创 ...
- POJ 1201 Intervals || POJ 1716 Integer Intervals 差分约束
POJ 1201 http://poj.org/problem?id=1201 题目大意: 有一个序列,题目用n个整数组合 [ai,bi,ci]来描述它,[ai,bi,ci]表示在该序列中处于[ai, ...
- 6.2、Android硬件访问服务编写系统代码
1.实现接口文件给App使用,接口文件是应用程序查询获得服务时获得 使用AIDL(Android接口定义语言)来实现ILedService.java接口 定义ILedService.aidl inte ...
- radare, the reverse engineering framework
History The radare project [http://radare.org/] started in February of 2006 aiming to provide a free ...
- PDO中获取结果集
fetch()方法 fetch()方法用于获取结果集的下一行.语法例如以下: mixed PDOStatement::fetch([int fetch_style][,int cursor_orien ...