C++ 教程

C++ 教程 C++ 简介 C++ 入门 C++ 语法 C++ 输出 C++ 注释 C++ 变量 C++ 用户输入 C++ 数据类型 C++ 运算符 C++ 字符串 C++ 数学运算 C++ 布尔值 C++ 条件语句 C++ Switch 语句 C++ While 循环 C++ For 循环 C++ Break/Continue 语句 C++ 数组 C++ 引用 C++ 指针

C++ 函数

C++ 函数 C++ 函数参数 C++ 函数重载

C++ 面向对象

C++ OOP C++ 类和对象 C++ 类方法 C++ 构造函数 C++ 访问修饰符 C++ 封装 C++ 继承 C++ 多态

C++ 高级教程

C++ 文件 C++ 异常处理 C++ 动态内存 C++ 命名空间 C++ 模板 C++ 预处理器 C++ 信号处理 C++ 多线程 C++ Web 编程 C++ 正则表达式

C++ 如何使用

C++ 两个数字相加

C++ 标准库参考

C++ 标准库 - 简介 C++ 标准库 - <fstream> C++ 标准库 - <iomanip> C++ 标准库 - <ios> C++ 标准库 - <iosfwd> C++ 标准库 - <iostream> C++ 标准库 - <istream> C++ 标准库 - <ostream> C++ 标准库 - <sstream> C++ 标准库 - <streambuf> C++ 标准库 - <atomic> C++ 标准库 - <complex> C++ 标准库 - <exception> C++ 标准库 - <functional> C++ 标准库 - <limits> C++ 标准库 - <locale> C++ 标准库 - <memory> C++ 标准库 - <new> C++ 标准库 - <numeric> C++ 标准库 - <regex> C++ 标准库 - <stdexcept> C++ 标准库 - <string> C++ 标准库 - <thread> C++ 标准库 - <tuple> C++ 标准库 - <typeinfo> C++ 标准库 - <utility> C++ 标准库 - <valarray>

C++ 模板库参考

C++ STL 库 - <array> C++ STL 库 - <bitset> C++ STL 库 - <deque> C++ STL 库 - <forward_list> C++ STL 库 - <list> C++ STL 库 - <map> C++ STL 库 - <queue> C++ STL 库 - <set> C++ STL 库 - <stack> C++ STL 库 - <unordered_map> C++ STL 库 - <unordered_set> C++ STL 库 - <vector> C++ STL 库 - <algorithm> C++ STL 库 - <iterator>

C++ 实例

C++ 实例 C++ 练习 C++ 测验



C++ 标准模板库 - <stack>

简介

堆栈是一种设计用于在 LIFO(后进先出)上下文中运行的数据结构。 在堆栈中,元素被插入以及仅从一端移除。

Stack 类是容器适配器。 容器是保存相同类型数据的对象。 可以从不同的序列容器创建堆栈。如果未提供容器,则使用默认的 deque 容器。 容器适配器不支持迭代器,因此我们不能将它们用于数据操作。但是它们分别支持 push()pop() 成员函数用于数据插入和删除。


定义

下面是来自 <stack> 头文件的 std::stack 定义

template <class T, class Container = deque<T> > class stack;

参数

  • T − 包含的元素的类型。

    T 可以替换为任何其他数据类型,包括用户定义的类型。

  • Container − 基础容器对象的类型。


成员类型

以下成员类型可以用作成员函数的参数或返回类型。

序号 成员类型 定义
1 value_type T (First parameter of the template)
2 container_type Second parameter of the template
3 size_type size_t
4 reference value_type&
5 const_reference const value_type&

<stack> 中的函数

下面是来自 <stack> 标头的所有方法的列表。

构造函数

序号 方法 & 说明
1 stack::stack default constructor

构造一个空的堆栈对象,其元素为零。

2 stack::stack copy constructor

构造一个堆栈,其中包含另一个堆栈中存在的每个元素的副本。

3 stack::stack move constructor

使用移动语义构造具有其他内容的堆栈。

析构函数

序号 方法 & 说明
1 stack::~stack

通过释放容器内存来销毁堆栈。

成员函数

序号 方法 & 说明
1 stack::emplace

在栈顶构造并插入新元素。

2 stack::empty

测试堆栈是否为空。

3 stack::operator= copy version

通过替换旧内容将新内容分配给堆栈。

4 stack::operator= move version

通过替换旧内容将新内容分配给堆栈。

5 stack::pop

从堆栈中移除顶部元素。

6 stack::push copy version

在栈顶插入新元素。

7 stack::push move version

在栈顶插入新元素。

8 stack::size

返回堆栈中存在的元素总数。

9 stack::swap

将堆栈的内容与另一个堆栈的内容交换。

10 stack::top

返回对栈顶元素的引用。

非成员重载函数

序号 方法 & 说明
1 operator==

测试两个堆栈是否相等。

2 operator!=

测试两个堆栈是否相等。

3 operator<

测试第一个堆栈是否小于其他堆栈。

4 operator<=

测试第一个堆栈是否小于或等于其他堆栈。

5 operator>

测试第一个堆栈是否大于其他堆栈。

6 operator>=

测试第一个堆栈是否大于或等于其他堆栈。

7 swap

交换两个堆栈的内容。