|
本文主讲C++ STL中的vector和list,介绍了部分接口函数,分析这连两个数据结构的优劣。 其实者两个就类似于之前C语言阶段的顺序表和双向链表。
vector
vector介绍
vector是表示可变大小数组的序列容器, 就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问,和数组一样高效。但是又不像数组,它的大小是可以动态改变的,而且它的大小会被容器自动处理。
vector接口
vector capacity
| 函数 | 功能 |
|---|
| size() | 返回实际元素个数。 | | resize() | 改变实际元素的个数。 | | capacity() | 返回当前容量。 | | empty() | 判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。 | | reserve() | 修改容器的容量 |
list modifiers
| 函数 | 功能 |
|---|
| push_back() | 在序列的尾部添加一个元素。 | | pop_back() | 移出序列尾部的元素。 | | insert() | 在指定的位置插入一个或多个元素。 | | erase() | 移出一个元素或一段元素。 | | clear() | 移出所有的元素,容器大小变为 0。 | | swap() | 交换两个容器的所有元素。 | | operator[ ] | 重载了 [ ]运算符,可以向访问数组中元素那样,通过下标即可访问甚至修改 vector 容器中的元素。 |
vector iterator
| 函数 | 功能 |
|---|
| begin() | 返回指向容器中第一个元素的迭代器。 | | end() | 返回指向容器最后一个元素所在位置后一个位置的迭代器,通常和 begin() 结合使用。 | | rbegin() | 返回指向最后一个元素的迭代器。 | | rend() | 返回指向第一个元素所在位置前一个位置的迭代器。 |
vector优劣
优:
劣:
- 空间不够需要增容,就可能导致频繁增容和空间浪费的问题
- 头部和中部插入数据时效率较低(因为需要挪动数据)
list
list介绍
STL list 容器,又称双向链表容器,即该容器的底层是以双向链表的形式实现的。这意味着,list 容器中的元素可以分散存储在内存空间里,而不是必须存储在一整块连续的内存空间中。 
list接口
这里只展示常用的
list capacity
| 函数 | 功能 |
|---|
| empty() | 判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。 | | size() | 返回当前容器实际包含的元素个数。 | | resize() | 调整容器的大小。 |
list element access
| 函数 | 功能 |
|---|
| front() | 返回第一个元素的引用。 | | back() | 返回最后一个元素的引用。 |
list modifiers
| 函数 | 功能 |
|---|
| push_front() | 在容器头部插入一个元素。 | | pop_front() | 删除容器头部的一个元素。 | | push_back() | 在容器尾部插入一个元素。 | | pop_back() | 删除容器尾部的一个元素。 | | insert() | 在容器中的指定位置插入元素。 | | erase() | 删除容器中一个或某区域内的元素。 | | swap() | 交换两个容器中的元素,必须保证这两个容器中存储的元素类型是相同的。 | | clear() | 删除容器存储的所有元素。 |
list Iterator
| 函数 | 功能 |
|---|
| begin() | 返回指向容器中第一个元素的双向迭代器。 | | end() | 返回指向容器中最后一个元素所在位置的下一个位置的双向迭代器。 | | rbegin() | 返回指向最后一个元素的反向双向迭代器。 | | rend() | 返回指向第一个元素所在位置前一个位置的反向双向迭代器。 | | cbegin() | 和 begin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | | cend() | 和 end() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | | crbegin() | 和 rbegin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | | crend() | 和 rend() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 |
list优劣
优:
劣:
- 不支持随机读取,访问后面的元素需要用一个指针从前往后访问。
其实看完这两个数据结构的优劣,不难看出这其实是两个互补的数据结构。
|