Sequential container

顺序容器有三种: vecotr、list和deque。它们的差别在于访问元素的方式, 以及添加或删除元素相关操作的运行代价。

Vector

  • resize 和 reserve的区别

    (1). vector的reserve增加了vector的capacity,但是它的size没有改变, 而resize改变了vector的capacity同时也增加了它的size。

    (2). reserve是容器预留空间,但在空间内不真正创建元素对象,所以在没有添加新的对象之前,不能引用容器内的元素。加入新的元素时,要调用push_back()/insert()函数。

    (3). resize是改变容器的大小,且在创建对象,因此,调用这个函数之后,就可以引用容器内的对象了,因此当加入新的元素时,用operator[]操作符,或者用迭代器来引用元素对象。此时再调用push_back()函数,是加在这个新的空间后面的。

    (4). 两个函数的参数形式也有区别的,reserve函数之后一个参数,即需要预留的容器的空间;resize函数可以有两个参数,第一个参数是容器新的大小, 第二个参数是要加入容器中的新元素,如果这个参数被省略,那么就调用元素对象的默认构造函数。

    (5). 不管是调用resize还是reserve,二者对容器原有的元素都没有影响。