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

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的一个重要问题在于:该操作不会删除或插入任何元素,而且保证在常量时间内实现交换。由于容器内没有移动任何元素,因此迭代器不会失效。

posted on 2013-06-28 11:01  胡永光  阅读(147)  评论(0编辑  收藏  举报

导航