您的位置:首页 > 编程语言 > C语言/C++

C++ Primer 有感(顺序容器)

2013-06-28 11:01 211 查看
1.顺序容器的元素排列次序与元素的值无关,而是由元素添加到容器里的次序决定。

2.

顺序容器

vector 支持快速随机访问

list 支持快速插入/删除

deque 双端队列

顺序容器适配器

stack 后进先出(栈)

queue 先进先出(队列)

priority_queue 有优先级管理的队列

3.容器元素的初始化

(1)将一个容器复制给另一个容器时,类型必须匹配:容器类型和元素类型都必须相同:

vector<int> ivec;
vector<int> ivec2(ivec);    //OK
list<int> ilist(ivec);    //error
vector<double> dvec(ivec);     //error


(2)尽管不能直接将一种容器内的元素复制给另一种容器,但系统允许通过传递一对迭代器间接实现该功能。使用迭代器时,不要求容器类型相同。容器内的元素类型也可以不相同,只要它们相互兼容,能够将要复制的元素转换为所构建的新容器的元素类型,即可实现复制。

4.C++语言中,大多数类型都可用作容器的元素类型。容器元素类型必须满足以下两个约束:

(1)元素类型必须支持赋值运算

(2)元素类型的对象必须可以复制

由于引用不支持一般意义的赋值运算,因此没有元素是引用类型的容器。IO标准库不支持复制或赋值,因此不能创建存放IO类型对象的容器。

5.在指定容器元素为容器类型时,必须如下使用空格:

vector< vector<string> > lines;

必须用空格隔开两个相连的>符号,以示这是两个分开的符号,否则,系统会认为>>是单个符号,为右移操作符,并结果导致编译时错误。

6.容器定义的类型别名

size_type 无符号整型,足以存储此容器类型的最大可能容器长度

iterator 此容器类型的迭代器类型

const_iterator 元素的只读迭代器类型

reverse_iterator 按逆序寻址元素的迭代器

const_reverse_iterator 元素的只读(不能写)逆序迭代器

difference_type 足够存储两个迭代器差值的有符号整型,可为负数

value_type 元素类型

reference 元素的左值类型,是value_type &的同义词

const_reference 元素的常量左值类型,等效于 const value_type &

在逆序迭代器上做++运算将指向容器中的前一个元素,最后三种类型使程序员无须直接知道容器元素的真正类型,就能使用它。需要使用元素类型时,只要用value_type即可。如果要引用该类型,则通过reference和const_reference实现。

7.容器的begin和end操作

c.begin() 返回一个迭代器,它指向容器C的第一个元素

c.end() 返回一个迭代器,它指向容器C的最后一个元素的下一个位置

c.rbegin() 返回一个逆序迭代器,它指向容器C的最后一个元素

c.rend() 返回一个逆序迭代器,它指向容器C的第一个元素前面的位置

8.任何insert或push操作都可能袋子迭代器失效。当编写循环将元素插入到vector或deque容器中时,程序必须确保迭代器在每次循环后都得到更新。

9.

c.back() 返回容器c的最后一个元素的引用。如果c为空,则该操作未定义

c.front() 返回容器c的第一个元素的引用。如果c为空,这该操作未定义

例如:

if (!ilist.empty()) {
list<int>::reference val = *ilist.begin();
list<init>::reference  val2 = ilist.front();
// last and last2 refer to the same element
list<int>::reference last = *--ilist.end();
list<int>::reference last2 = ilist.back();


10.顺序容器的赋值操作

c1 = c2 删除容器c1的所有元素,然后将c2的元素复制给c1。c1和c2的类型(包括容器类型和元素类型)必须相同。

c1.swap(c2) 交换内容:调用完该函数后,c1中存放的是c2原来的元素,c2中存放的则是c1原来的元素。c1和c2的类型必须相同。该函数的执行速度通常要比将c2的元素复制到c1的操作快

c.assign(b,e) 重新设置c的元素:将迭代器b和e标记的范围内所有的元素复制到c中。b和e必须不是指向c中元素的迭代器

c.assign(n,t) 将容器c重新设置为存储n个值为t的元素。

注意:

assign操作首先删除容器中所有的元素,然后将其参数所指定的新元素插入到该容器中。如果在不同(或相同)类型的容器内,元素类型相互兼容,则其赋值运算必须使用assign函数。

swap操作要求交换的容器的类型必须匹配:操作数必须是相同类型的容器,而且所存储的元素类型也必须相同。关于swap的一个重要问题在于:该操作不会删除或插入任何元素,而且保证在常量时间内实现交换。由于容器内没有移动任何元素,因此迭代器不会失效。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: