C++ Primer : 第九章 : 顺序容器的定义、迭代器以及赋值与swap
顺序容器属于C++ STL的一部分,也是非常重要的一部分。
顺序容器包括:
std::vector,包含在头文件<vector>中
std::string, 包含在头文件<string>中
std::deque,包含在头文件<deque>中
std::list,包含在头文件<list>中
std::forward_list,包含在头文件<forward_list>中
std::array, 包含在头文件<array>中
顺序容器几乎可以保存任意类型的元素,我们可以定义一个容器,其元素类型可以是另一个容器。顺序容器的构造函数的一个版本接受容器大小的参数,它使用了元素类型的默认构造函数,但有些类没有构造函数,我们可以定义一个保存这种类型对象的容器,但我们在构造这种容器时不能只传递给它一个元素数目的参数,必须提供一个元素初始化器。
迭代器
迭代器支持的操作有:*iter,iter->mem,++iter,--iter, iter1 == iter2, iter1 != iter2
另外,forward_list::iterator 不支持递减--操作。
另外,string、vector、deque、array的迭代器支持这些算数运算符:
iter + n, iter - n, iter += n, iter -= n, iter1 - iter2, >、>=、<、<=
迭代器的范围是 [begin, end),首迭代器和尾后迭代器。
容器的定义和初始化
C c;
默认构造函数,如果C是一个array,则c中元素按默认方式初始化,否则c为空;
C c1(c2); c1位c2的一个拷贝,c1和c2的容器类型必须相同,而且保存的是相同的类型,
C c1=c2; 如果C是array,它们的大小必须相同;
C c{a,b,c,...}; c初始化为初始化列表的中元素,列表中的元素必须与c的元素类型相容。
C c={a,b,c,...}; 对于array类型,列表中的元素个数必须等于或小于array的大小,如果小于,array剩余的元素进行值初始化
C c(b, e);
c初始化为迭代器b到e(不包括e)之间的元素,迭代器所指向的元素必须与c中元素类型相容
只有顺序容器(不包括array)的构造函数才接受大小参数
C seq(n);
seq包含了n个元素,这些元素都进行了值初始化,此构造函数时explicit的
C seq(n,t); seq包含n个值为 t 的元素
将一个容器拷贝为另一个容器时,两个容器的类型和保存的类型必须匹配,当array进行拷贝时,它的大小还必须相等;
不过,当使用迭代器参数来拷贝元素时,就不要求两个容器必须是同一种容器了,只要两者保存的元素类型能相容就行。
array的定义和初始化:
定义一个array时,需要制定元素类型和大小。
列表初始化array时,列表中的元素个数不能超过array大小,如果个数小于array大小,将初始化array靠前的元素,剩下的进行值初始化,如果array保存的类型时类类型,则该类必须有一个默认构造函数,以便值初始化能够进行。
赋值和swap
c1 = c2;// 将c1的内容替换为c2中元素的拷贝
c1 = {a, b, c};// 赋值后, c1的大小为3
array也可以整体赋值,这正是array与内置数组的不同之处; array在赋值时,赋值符号左右两边的对象必须具有相同的类型。
array<int, 5> a1 = {1, 2, 3, 4, 5};
array<int, 5> a2 = {6, 7, 8, 9, 10};
a1 = a2; // a1中元素将替换为a2中元素的拷贝
但不能将一个花括号列表赋值数组:
a2 = {0}; // error
容器的赋值运算有如下几种:
c1 = c2;
c = {a, b, c};
swap(c1, c2); 将c1中元素替换为c2中的元素,c1和c2必须具有相同的类型
c1.swap(c2); swap通常比从c2向c1拷贝元素快的多。
// assign操作不适用于关联容器和array
seq.assign(b, e); 将seq中元素替换为迭代器b和e所指向的范围之内的元素,但是b和e不能指向seq
seq.assign(il); 将seq中元素替换为初始化列表il中的元素</span>
seq.assign(n, val); 将seq中元素替换为n个值为val的元素</span>
赋值相关运算会导致指向左边容器内部的迭代器、引用和指针失效。而swap操作将容器内容交换不会导致失效。(array和string的情况除外)
使用swap
swap操作的是两个相同类型容器的内容。除array外,交换两个容器内部的操作保证会很快,元素本身并未交换,swap只是交换了两个容器内部的数据结构。
元素不会被移动,这意味着,string除外,指向容器的迭代器、引用和指针在swap操作后不会失效。但在swap之后,这些元素已经属于不同的容器了。例如有两个容器vec1和vec2,假定iter1在swap前指向vec1[3], 在swap之后它指向vec2[3]。 但是,对一个string调用swap会导致迭代器、引用和指针失效。
swap两个array会真正的交换他们的元素,所以交换array所需要的时间和array的元素数目成正比。
新的标准库中,容器既提供成员函数版本的swap,也提供非成员函数版本的swap,我们应该习惯使用非成员版本的swap。
容器大小操作
每个容器类型都支持相等运算符 == 和 != ; 除了无需关联容器外,所有容器都支持关系运算符 >、>=、<、<= 。关系运算符左右两边的对象必须是相同类型的容器,且必须保存相同类型的元素。
实际上,容器进行比较时,使用的是元素的关系运算符完成比较,因此,只有当容器储存的元素类型定义了相应的关系运算符时,我们才可以进行关系比较!
C++ Primer : 第九章 : 顺序容器的定义、迭代器以及赋值与swap的更多相关文章
- C++ Primer 第九章 顺序容器
由于书籍上写的已经很经典了,故大部分用图片的形式来阐述概念,代码纯手打进行验证. 1.顺序容器类型:vector.deque.list.forword_list.array.string. 2.顺序容 ...
- C++ Primer : 第九章 : 顺序容器的操作以及迭代器失效问题
顺序容器的添加.访问.删除操作以及forward_list的特殊操作,还有迭代器失效问题. 一.向容器添加元素 // array不支持这些操作 // forward_list有自己撰于的版本的inse ...
- C++ Primer 读书笔记: 第9章 顺序容器
第9章 顺序容器 引: 顺序容器: vector 支持快速随机访问 list 支持快速插入/删除 deque 双端队列 顺序容器适配器: stack 后进先出栈 queue 先进先出队列 priori ...
- cb06a_c++_顺序容器的定义
/*cb06a_c++_顺序容器的定义顺序容器:vector,数组,尾端操作数据,快速随机访问list 链表,快速插入数据deque数组,双端-首尾操作数据,方便两端的数据访问 顺序容器适配器:sta ...
- C++ Primer : 第九章 : vector变长、string的其他操作以及容器适配器
vector变长机制.string的其他构造方法,添加.替换和搜索操作,string比较和数值转换,最后是容器适配器. vector对象是如何增长的 vector和string类型提供了一些成员函数, ...
- C++ Primer 5th 第9章 顺序容器
练习9.1:对于下面的程序任务,vector.deque和list哪种容器最为适合?解释你的选择的理由.如果没有哪一种容器优于其他容器,也请解释理由.(a) 读取固定数量的单词,将它们按字典序插入到容 ...
- [C++ Primer] 第9章: 顺序容器
顺序容器概述 顺序容器的类型有: 类型 说明 vector 可变长度数组. 支持快速随机访问. deque 双端队列. 支持快速随机访问. list 双向链表. 只支持双向顺序访问. forward_ ...
- 《C++ Primer》笔记 第9章 顺序容器
顺序容器类型 类型 解释 vector 可变大小数组.支持快速随机访问.在尾部之外的位置插入或删除元素可能很慢 deque 双端队列.支持快速随机访问.在头尾位置插入.删除速度很快 list 双向链表 ...
- 【c++ Prime 学习笔记】第9章 顺序容器
一个容器是特定类型对象的集合 顺序容器中元素的顺序与其加入容器的位置对应 关联容器中元素的顺序由其关联的关键字决定,关联容器分为有序关联容器和无序关联容器 所有容器类共享公有接口,不同容器按不同方式扩 ...
随机推荐
- NOIP 2000解题报告
题目简单,思路很快就有,关键是代码实现能力,大概3个多小时完成.第一题:题目大意:将一个10进制数N转换成-B进制数 (负进制转换):B<=20, N(-32768<=N<=3276 ...
- jquery easyui DataGrid 动态的改变列显示的顺序
$.extend($.fn.datagrid.methods,{ columnMoving: function(jq){ return jq.each(function(){ var target = ...
- sql 行专列 列转行 普通行列转换
转载:http://www.cnblogs.com/newwind521/archive/2010/11/25/1887203.html sql 行专列 列转行 普通行列转换 /* 标题:普通行列转换 ...
- BPM与OA,选择好烦恼!
企业在信息化建设的过程中 难免遭遇BPM和OA之争, 难!难!难! 选择BPM吧, 有人觉得你“打肿脸充胖子”: 选择OA嘛, “行业大哥”们已经在BPM的路上越走越远… 其实, OA和BPM从某种意 ...
- Coudera-Manager/CDH的安装和部署
由于之前部署的集群采用的是用apache hadoop的方式来实现,但是考虑到运维的成本问题,下面将apache hadoop转换成cloudera cdh.下面主要讲解一下cloudera cdh的 ...
- 等价表达式(noip2005)
3.等价表达式 [问题描述] 兵兵班的同学都喜欢数学这一科目,中秋聚会这天,数学课代表给大家出了个有关代数表达式的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也 ...
- 04-树5 Complete Binary Search Tree
这题也是第二次做,本想第一次做时参考的算法会和老师讲的一样,不想老师讲的算法用在这题感觉还不如思雪园友的算法(http://www.cnblogs.com/sixue/archive/2015/04. ...
- hdu 2037
PS: - -原本想的是排序开始时间和消耗时间..后来想到可以排序结束时间..后来还wa了一次,因为排序的时候溢出了 思路: 1 3 //13 4 //20 7 3 8 2 9 5 10 //36 ...
- iOS:死锁
死锁:指多个进程因竞争共享资源而造成的一种僵局,若无外力作用,这些进程都将永远不能再向前推进. 安全状态与不安全状态:安全状态指系统能按某个进程顺序来为每个进程分配其所需资源,直至最大需求,使每个进程 ...
- HDU1272-小希的迷宫(并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1272 #include<cstdio> #include<cstring> u ...