【C++STL基础入门】queue基础使用

简介: 【C++STL基础入门】queue基础使用

前言


C++标准模板库(STL)提供了一系列强大的容器和算法,方便我们在编程中处理数据和实现各种功能。其中,queue(队列)是STL中的一个重要容器,用于按照先进先出(FIFO)的顺序处理元素。本文将介绍queue的基础使用方法,帮助读者初步掌握队列的概念和操作。


一、队列是什么


当我们排队等待服务时,我们按照先来先服务的原则进行,这就是队列的概念。队列是一种数据结构,类似于现实生活中的排队场景。想象你在超市排队结账,新来的顾客会站在队列的最后,而服务员会从队列的前面开始依次为顾客提供服务。这就是队列的特点:先进入队列的元素会先被处理,而后进入队列的元素需要等待前面的元素处理完毕才能轮到它们。


在计算机编程中,队列也是如此。我们可以将队列看作是一个容器,只能在一端添加元素(队尾),而只能在另一端移除元素(队头)。新的元素进入队列时,会被放置在队尾,而需要被处理的元素则从队头被取出。这种先进先出(FIFO)的规则使得队列非常适用于按照顺序处理任务或事件的场景。


通过队列,我们可以按照特定的顺序处理数据,确保按照先后顺序进行操作。无论是处理请求、处理消息还是进行任务调度,队列都提供了一种有序的方式来管理数据。因此,理解队列的概念对于编程和问题解决非常重要。


二、queue的基础使用


2.1 queue的构造函数

以下是对每个构造函数的功能和参数的含义的解释:

无参构造函数:

功能:创建一个空的队列对象。

参数:该构造函数没有任何参数。

示例代码:

#include <iostream>
#include <queue>
int main() {
    // 创建一个空队列
    std::queue<int> myQueue;
    return 0;
}


19a4b4b1de584dd49009e592bebc830f.png

queue(const queue& other):

功能:创建一个新队列,该队列是通过拷贝另一个队列 other 中的元素而构建的。

参数:另一个队列 other,用于拷贝元素的源队列。

示例代码:

#include <iostream>
#include <queue>
int main() {
    std::queue<int> sourceQueue;
    sourceQueue.push(10);
    sourceQueue.push(20);
    sourceQueue.push(30);
    // 通过拷贝构造函数创建新队列
    std::queue<int> targetQueue(sourceQueue);
    return 0;
}


74697153c3e74d628e7f9432dc02f092.png

queue(queue&& other)(C++11 起):

功能:创建一个新队列,该队列通过移动另一个队列 other 中的元素而构建的。

参数:另一个队列 other,用于移动元素的源队列。

示例代码:

#include <iostream>
#include <queue>
int main() {
    std::queue<int> sourceQueue;
    sourceQueue.push(10);
    sourceQueue.push(20);
    sourceQueue.push(30);
    // 通过移动构造函数创建新队列
    std::queue<int> targetQueue(std::move(sourceQueue));
    return 0;
}


0618230f85c94426af8060f11b5109c1.png

template< class InputIt > queue(InputIt first, InputIt last):


功能:创建一个新队列,该队列包含从迭代器 first 到迭代器 last 范围内的元素。

参数:first 和 last 是迭代器,表示一个范围,用于指定要复制到新队列中的元素的起始和结束位置。

template< class Alloc > queue(const Container& cont, const Alloc& alloc)(C++23 起):


功能:创建一个新队列,该队列包含容器 cont 中的元素,并使用给定的分配器 alloc。

参数:cont 是一个容器,用于提供要复制到新队列中的元素。alloc 是用于内存分配的分配器。


2.2 queue的属性函数


总结


在本文中,我们学习了如何使用C++ STL中的queue容器。队列是一种非常有用的数据结构,适用于按照先进先出的顺序处理元素的场景。我们掌握了插入元素、获取队列头部和尾部的元素,以及遍历和移除队列元素的基本操作。


使用queue可以使我们的程序更加高效和易于实现。期望本文对于初学者理解queue的基本概念和使用有所帮助。继续学习和掌握STL的各种容器和算法,将使我们在编程中更加得心应手。


希望本文对你有所帮助,谢谢阅读!

相关文章
|
22天前
|
编译器 C语言 C++
【c++丨STL】list模拟实现(附源码)
本文介绍了如何模拟实现C++中的`list`容器。`list`底层采用双向带头循环链表结构,相较于`vector`和`string`更为复杂。文章首先回顾了`list`的基本结构和常用接口,然后详细讲解了节点、迭代器及容器的实现过程。 最终,通过这些步骤,我们成功模拟实现了`list`容器的功能。文章最后提供了完整的代码实现,并简要总结了实现过程中的关键点。 如果你对双向链表或`list`的底层实现感兴趣,建议先掌握相关基础知识后再阅读本文,以便更好地理解内容。
27 1
|
1月前
|
算法 C语言 C++
【c++丨STL】list的使用
本文介绍了STL容器`list`的使用方法及其主要功能。`list`是一种双向链表结构,适用于频繁的插入和删除操作。文章详细讲解了`list`的构造函数、析构函数、赋值重载、迭代器、容量接口、元素访问接口、增删查改操作以及一些特有的操作接口如`splice`、`remove_if`、`unique`、`merge`、`sort`和`reverse`。通过示例代码,读者可以更好地理解如何使用这些接口。最后,作者总结了`list`的特点和适用场景,并预告了后续关于`list`模拟实现的文章。
51 7
|
2月前
|
存储 编译器 C语言
【c++丨STL】vector的使用
本文介绍了C++ STL中的`vector`容器,包括其基本概念、主要接口及其使用方法。`vector`是一种动态数组,能够根据需要自动调整大小,提供了丰富的操作接口,如增删查改等。文章详细解释了`vector`的构造函数、赋值运算符、容量接口、迭代器接口、元素访问接口以及一些常用的增删操作函数。最后,还展示了如何使用`vector`创建字符串数组,体现了`vector`在实际编程中的灵活性和实用性。
97 4
|
2月前
|
C语言 C++ 容器
【c++丨STL】string模拟实现(附源码)
本文详细介绍了如何模拟实现C++ STL中的`string`类,包括其构造函数、拷贝构造、赋值重载、析构函数等基本功能,以及字符串的插入、删除、查找、比较等操作。文章还展示了如何实现输入输出流操作符,使自定义的`string`类能够方便地与`cin`和`cout`配合使用。通过这些实现,读者不仅能加深对`string`类的理解,还能提升对C++编程技巧的掌握。
101 5
|
1月前
|
存储 编译器 C语言
【c++丨STL】vector模拟实现
本文深入探讨了 `vector` 的底层实现原理,并尝试模拟实现其结构及常用接口。首先介绍了 `vector` 的底层是动态顺序表,使用三个迭代器(指针)来维护数组,分别为 `start`、`finish` 和 `end_of_storage`。接着详细讲解了如何实现 `vector` 的各种构造函数、析构函数、容量接口、迭代器接口、插入和删除操作等。最后提供了完整的模拟实现代码,帮助读者更好地理解和掌握 `vector` 的实现细节。
46 0
|
12天前
|
C++ 芯片
【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
声明一个简单的Computer类,含有数据成员芯片(cpu)、内存(ram)、光驱(cdrom)等等,以及两个公有成员函数run、stop。只能在类的内部访问。这是一种数据隐藏的机制,用于保护类的数据不被外部随意修改。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。成员可以在派生类(继承该类的子类)中访问。成员,在类的外部不能直接访问。可以在类的外部直接访问。为了完成本关任务,你需要掌握。
52 18
|
12天前
|
存储 编译器 数据安全/隐私保护
【C++面向对象——类与对象】CPU类(头歌实践教学平台习题)【合集】
声明一个CPU类,包含等级(rank)、频率(frequency)、电压(voltage)等属性,以及两个公有成员函数run、stop。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。​ 相关知识 类的声明和使用。 类的声明和对象的声明。 构造函数和析构函数的执行。 一、类的声明和使用 1.类的声明基础 在C++中,类是创建对象的蓝图。类的声明定义了类的成员,包括数据成员(变量)和成员函数(方法)。一个简单的类声明示例如下: classMyClass{ public: int
38 13
|
12天前
|
编译器 数据安全/隐私保护 C++
【C++面向对象——继承与派生】派生类的应用(头歌实践教学平台习题)【合集】
本实验旨在学习类的继承关系、不同继承方式下的访问控制及利用虚基类解决二义性问题。主要内容包括: 1. **类的继承关系基础概念**:介绍继承的定义及声明派生类的语法。 2. **不同继承方式下对基类成员的访问控制**:详细说明`public`、`private`和`protected`继承方式对基类成员的访问权限影响。 3. **利用虚基类解决二义性问题**:解释多继承中可能出现的二义性及其解决方案——虚基类。 实验任务要求从`people`类派生出`student`、`teacher`、`graduate`和`TA`类,添加特定属性并测试这些类的功能。最终通过创建教师和助教实例,验证代码
37 5
|
12天前
|
存储 算法 搜索推荐
【C++面向对象——群体类和群体数据的组织】实现含排序功能的数组类(头歌实践教学平台习题)【合集】
1. **相关排序和查找算法的原理**:介绍直接插入排序、直接选择排序、冒泡排序和顺序查找的基本原理及其实现代码。 2. **C++ 类与成员函数的定义**:讲解如何定义`Array`类,包括类的声明和实现,以及成员函数的定义与调用。 3. **数组作为类的成员变量的处理**:探讨内存管理和正确访问数组元素的方法,确保在类中正确使用动态分配的数组。 4. **函数参数传递与返回值处理**:解释排序和查找函数的参数传递方式及返回值处理,确保函数功能正确实现。 通过掌握这些知识,可以顺利地将排序和查找算法封装到`Array`类中,并进行测试验证。编程要求是在右侧编辑器补充代码以实现三种排序算法
28 5
|
12天前
|
Serverless 编译器 C++
【C++面向对象——类的多态性与虚函数】计算图像面积(头歌实践教学平台习题)【合集】
本任务要求设计一个矩形类、圆形类和图形基类,计算并输出相应图形面积。相关知识点包括纯虚函数和抽象类的使用。 **目录:** - 任务描述 - 相关知识 - 纯虚函数 - 特点 - 使用场景 - 作用 - 注意事项 - 相关概念对比 - 抽象类的使用 - 定义与概念 - 使用场景 - 编程要求 - 测试说明 - 通关代码 - 测试结果 **任务概述:** 1. **图形基类(Shape)**:包含纯虚函数 `void PrintArea()`。 2. **矩形类(Rectangle)**:继承 Shape 类,重写 `Print
33 4