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) 的要求。另外,它必须提供拥有通常语义的下列函数:

标准容器 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

成员对象

成员名称 定义
Container c
底层容器
(受保护成员对象)

成员函数

非成员函数

构造 stack
(公开成员函数)
析构 stack
(公开成员函数)
将值赋给容器适配器
(公开成员函数)
元素访问
访问栈顶元素
(公开成员函数)
容量
检查容器适配器是否为空
(公开成员函数)
返回元素数
(公开成员函数)
修改器
向栈顶插入元素
(公开成员函数)
在栈顶插入元素范围
(公开成员函数)
(C++11)
在顶部原位构造元素
(公开成员函数)
移除栈顶元素
(公开成员函数)
(C++11)
交换内容
(公开成员函数)
按照字典顺序比较两个 stack 的值
(函数模板)
特化 std::swap 算法
(函数模板)

辅助类

特化 std::uses_allocator 类型特征
(类模板特化)
std::stack 的格式化支持
(类模板特化)

推导指引

(C++17 起)

注解

功能特性测试 标准 功能特性
__cpp_lib_containers_ranges 202202L (C++23) 容器的范围构造和插入

示例

Comment

#include <iostream>
#include <stack>
 
int main()
{
    struct Point
    {
        int x, y;
    };
    std::stack<Point> stack;
 
    // push
    stack.push({1, 1});
    stack.push({2, 1});
    stack.push({.x = 3, .y = 0});
 
    // emplace -  (C++11)
    stack.emplace(4, 4);
    auto [x, y] = stack.emplace(Point{5, 5}); // c++17
    std::cout << "x: " << x << ",y: " << y << '\n';
 
    // pop
    stack.pop();
 
    while (!stack.empty())
    {
        auto [a, b] = stack.top();
        std::cout << "a: " << a << ",b: " << b << '\n';
        stack.pop();
    }
 
    return 0;
}

输出:

x: 5,y: 5
a: 4,b: 4
a: 3,b: 0
a: 2,b: 1
a: 1,b: 1

缺陷报告

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

缺陷报告 应用于 出版时的行为 正确行为
LWG 307 C++98 Container 不能是 std::vector<bool> 可以是
LWG 2566 C++98 缺少对 Container::value_type 的要求 TContainer::value_type 不同时非良构

参阅

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