###STL学习--vector
点击查看Evernote原文。
#@author: gr
#@date: 2014-08-11
#@email: forgerui@gmail.com
vector的相关问题。《stl学习》将按内容进行整理,不再把所有内容放到一个文件中。
###stl学习
|--迭代器
|--类属算法
|--容器
|--vector
|--deque
|--list
|--set
|--map
|--函数对象
|--适配器
|--分配器
一、Contents
1. 强大的迭代器
因为vector的迭代器是随机迭代器,即最强大的迭代器,所以一般的类属算法都可以支持. 如sort算法, list(链表)便不支持sort类属算法, 而对list增加了sort成员函数.
2. vector构造函数
int n = 10;
//初始n个"T value"
vector<T> v1(n, value);
//第二个参数是默认参数,默认为T(),向量的每个成员都是T()的拷贝构造函数得来,
//可以理解为先使用T a初始化一个对象a,之后每个向量的元素都是调用拷贝构造函数T(T& a)得来的对象
vector<T> v2(n);
//从其它容器中拷贝
char a[] = "hello";
vector<char> v3(a, a+5);
vector<int> v4(list1.begin(), list1.end());
3. 插入
vector提供了随机访问的功能,说明其访问时间是常数的,但其插入和删除时间则是线性的。所以,在末尾插入用vector, 在末尾和头部插入用双向队列(deque),大量进行插入删除操作时使用链表(list)。
//push_back压入最后
vector<int> v;
v.push_back(2);
//insert插入任何位置
v.insert(position, value);
4. capacity与size
capacity: 向量已经申请到的内存空间大小
size: 向量已经分配元素的大小
一般,capacity() >= size()
。
5. vector的内存分配问题
当初始化一个空vector时,默认内存大小为0;可以通过capacity查看。
第一次申请空间大小个数为1024,如果使用空间超过capacity,再次插入时就会扩大2倍。
具体做法是重新申请原来内存2倍的空间,并将原来的数据拷贝到新申请的内存中,释放掉原来的内存。这样做的原因是vector需要按顺序连续存储在一段空间中。虽然,重新分配内存和拷贝数据需要很大的开销,但这种情况很少出现一次,把它平均分摊到每个插入操作,复杂度仍可以维持在常数。
//初始化一个空向量
vector<int> a;
assert(a.capacity() == 0);
//增加内存,申请大小为1024
a.push_back(1);
assert(a.capacity() == 1024);
6.使用reserve提高效率
上面提到,vector动态申请内存的开销问题,如果可以事先确定需要的大小,可以使用reserve一次性申请这段空间。
//不提前申请空间,需要申请多次,1024,2048,4096,8192,16384,造成了多次开销
vector<int> v1;
for(int i=0; i<1000; i++){
v1.push_back(i);
}
//一次性申请10000空间,可以有效减少开销
vector<int> v2;
v2.reserve(10000);
for(int i=0; i<1000; i++){
v1.push_back(i);
}
7. 删除
在删除末尾以外地方的元素需要将后面的元素进行移动,时间复杂度是线性的。删除点之后的迭代器失效,所以erase(j++)是值得考量的;
//pop_back
vector<int> a;
a.pop_back();
//erase,删除position位置上的元素
a.erase(position);
//erase,删除[first, last)上的元素
a.erase(iterator first, iterator last);
//删除向量v1的第一个元素
a.erase(v1.begin());
8. 访问器
访问器是vector的成员函数,只获取向量的信息,不改变向量的状态。
size_type size(), capacity(),
iterator begin(), end()
reference front(), back(), [], at()
bool empty()
9. 向量的swap函数
部分特殊化定义(partial specialization):将模板参数类型更加具体化
当存在两个模板函数时,特殊化程度高的函数会被调用。这样,各个容器的swap函数会比最普通的swap调用的优先级更高。实现了针对各个容器的快速算法,这些容器的swap函数都是常数的时间复杂度。
//最普适的swap
template <typename T>
void swap(T& a, T& b){
T temp = a;
a = b;
b = temp;
}
//特殊化的swap,将T变为vector<U>,当遇到vector时,会先调用这个swap
template <typename U>
void swap(vector<U>& a, vector<U>& b){
a.swap(b);
}
//调用swap,优先使用向量的swap,即有vector1.swap(vector2);
swap(vector1, vector2);
二、Miscellany
@author gr
@mail forgerui@gmail.com
###STL学习--vector的更多相关文章
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
- STL学习:STL库vector、string、set、map用法
本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...
- Effective STL 学习笔记: 多用 vector & string
Effective STL 学习笔记: 多用 vector & string 如果可能的话, 尽量避免自己去写动态分配的数组,转而使用 vector 和 string . 原书作者唯一想到的一 ...
- 侯捷STL学习(七)--深度探索vector&&array
layout: post title: 侯捷STL学习(七) date: 2017-06-13 tag: 侯捷STL --- 第十六节 深度探索vector vector源码剖析 vector内存2倍 ...
- C++STL之Vector向量详解,用法和例子 一起学习 一起加油
C++ STL之vector用法总结 1 ...
- STL学习笔记序言
笔者作为计算机科学与技术专业的学生,学习并使用C++已经有3年了.在接触STL之前的编程习惯是,所有程序的功能包括数据结构.算法等都是亲自实现,效率极其缓慢.后来从使用STL的vector开始慢慢的感 ...
- ###STL学习--关联容器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的关联容器. ###stl学习 |--迭 ...
- ###STL学习--迭代器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的迭代器. ###stl学习 |--迭代 ...
- ###STL学习--函数对象
点击查看Evernote原文. #@author: gr #@date: 2014-08-13 #@email: forgerui@gmail.com 在stl中,函数对象被大量地使用,用以提高代码的 ...
随机推荐
- stm32 cortext-M3 类型对齐问题【worldsing笔记】
经过细测,Cortex-M3的double类型必须4字节对齐访问,其他诸如float,int,short 可以非对齐访问.否则将会产生硬件异常!即访问double类型地址必须能被4整除,测试代码如下: ...
- C#将对象转换成JSON字符串,Newtonsoft.Json (JSON.NET)
官方API说明文档 http://www.newtonsoft.com/json/help/html/N_Newtonsoft_Json.htm http://www.newtonsoft.com/ ...
- ECSHOP在线手册布局参考图--登录/注册页 user_passport.dwt
A.会员登录框 1,设置方法 自带模块 2,代码相关 user_passport.dwt 中 <div class="usBox_1 f_l"> <div ...
- linux 下部署 java quartz job
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- 滑雪_poj_1088(记忆化搜索).java
滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 67987 Accepted: 25013 Description ...
- Matlab画图-非常具体,非常全面
Matlab画图 强大的画图功能是Matlab的特点之中的一个,Matlab提供了一系列的画图函数,用户不须要过多的考虑画图的细节,仅仅须要给出一些基本參数就能得到所需图形,这类函数称为高层画图函数. ...
- iOS开发——数据持久化Swift篇&通用文件存储
通用文件存储 import UIKit class ViewController: UIViewController { @IBOutlet weak var textField: UITextFie ...
- BAPI_ACC_DOCUMENT_POST Enter rate / GBP rate type M for Error SG105
Folks, I was wondering if I could get a bit of help here as I've been racking my brains on it for ag ...
- Jordan Lecture Note-3: 梯度投影法
Jordan Lecture Note-3:梯度投影法 在这一节,我们介绍如何用梯度投影法来解如下的优化问题: \begin{align} \mathop{\min}&\quad f(x)\n ...
- 启动android程序和虚拟机时候出现如下错误的解决方法
启动android程序和虚拟机时候出现如下错误的解决方法. 错误重现: [2011-07-13 16:22:48 - Emulator] invalid command-line parameter: ...