STL 常用库简介

Standard Template Library (STL) :标准模板库。主要分为三类:算法(Algorithm)、容器(Container)和迭代器(Iterator)。在C++标准中,STL被组织为下面的13个头文件:

Algorithm有:

<algorithm> 模板函数组成,涉及比较、交换、查找、遍历操作、复制、修改、移除、反转、排序、合并等等。

<functional> 定义了一些模板类,用以声明函数对象。

<numeric> 在序列上面进行简单数学运算的模板函数。

Container有:

<set> 集合:一种包含已排序对象的关联容器。set/multiset会根据待定的排序准则,自动将元素排序。两者不同在于前者不允许元素重复,而后者允许。

<map> 映射:由{键,值}对组成的集合。mapmultimapsetmultiset非常相似,他们里面的元素也都是“有序的”。也会根据规定的排序准则排序。不同的是mapmultimap的元素都是键/值对的形式。

<stack> 栈:后进先出的值的排列。

<queue> 队列:先进先出的值的排列。 

<deque> 双向队列:连续存储的指向不同元素的指针所组成的数组。

<vector> 向量:连续存储的元素。类似于数组,但另加一些方便的操作。

<list> 列表:由节点组成的双向链表,每个结点包含着一个元素。

Iterator有:

<iterator> 提供了迭代器使用的许多方法。

<memory> 以不同寻常的方式为容器中的元素分配存储空间,同时也为某些算法执行期间产生的临时对象提供机制,主要部分是模板类allocator,它负责产生所有容器中的默认分配器。

<utility> 包括了贯穿使用在STL中的几个模板的声明,常用的pair就包含在内。

文章来源

你可能感兴趣的:(STL)