std::stack

来自cppreference.com
< cpp‎ | container
在标头 <stack> 定义
template<

    class T,
    class Container = std::deque<T>

> class stack;

std::stack 类是容器适配器,它给予程序员栈的功能——特别是 FILO(先进后出)数据结构。

该类模板表现为底层容器的包装器——只提供特定函数集合。栈从被称作栈顶的容器尾部推弹元素。

模板形参

T - 存储的元素类型。 TContainer::value_type 不是同一类型时行为未定义。
Container - 用于存储元素的底层容器类型。容器必须满足序列容器 (SequenceContainer) 的要求。另外,它必须提供拥有通常语义的下列函数:
  • back()
  • push_back()
  • pop_back()

标准容器 std::vector(包括 std::vector<bool>)、std::dequestd::list 满足这些要求。如果没有为特定的 stack 类特化指定容器类,那么就会使用标准容器 std::deque


成员类型

成员类型 定义
container_type Container
value_type Container::value_type
size_type Container::size_type
reference Container::reference
const_reference Container::const_reference

成员函数

构造 stack
(公开成员函数)
析构 stack
(公开成员函数)
赋值给容器适配器
(公开成员函数)
元素访问
访问栈顶元素
(公开成员函数)
容量
检查底层容器是否为空
(公开成员函数)
返回容纳的元素数
(公开成员函数)
修改器
向栈顶插入元素
(公开成员函数)
(C++11)
在顶部原位构造元素
(公开成员函数)
删除栈顶元素
(公开成员函数)
(C++11)
交换内容
(公开成员函数)

成员对象

Container c
底层容器
(受保护成员对象)

非成员函数

按照字典顺序比较 stack 中的值
(函数模板)
特化 std::swap 算法
(函数模板)

辅助类

特化 std::uses_allocator 类型特征
(类模板特化)

推导指引(C++17 起)

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 307 C++98 Container 不能是 std::vector<bool> 可以是

参阅

动态的连续数组
(类模板)
节省空间的动态 bitset
(类模板特化)
双端队列
(类模板)
双链表
(类模板)