0

0

C++怎么实现一个线程安全的队列_C++使用互斥锁和条件变量构建并发队列

穿越時空

穿越時空

发布时间:2025-11-23 17:30:21

|

1009人浏览过

|

来源于php中文网

原创

线程安全队列通过互斥锁保护共享数据、条件变量实现线程同步,确保生产者-消费者模型中多线程并发访问时的数据一致性与高效协作。

c++怎么实现一个线程安全的队列_c++使用互斥锁和条件变量构建并发队列

在C++多线程编程中,实现一个线程安全的队列是常见的需求。比如生产者-消费者模型就需要多个线程同时访问同一个队列,而不会引发数据竞争或状态不一致的问题。通过使用互斥锁(std::mutex)和条件变量(std::condition_variable),我们可以构建一个高效且安全的并发队列。

基本设计思路

线程安全队列的核心目标是:确保任意数量的生产者和消费者可以并发地入队和出队,而不会破坏内部数据结构或导致竞态条件。

关键点包括:

  • 使用互斥锁保护对队列的读写操作,防止多个线程同时修改队列。
  • 使用条件变量通知等待的线程——当队列为空时,消费者等待;当有新元素加入时,唤醒消费者。
  • 避免忙等待,提高效率。

使用 std::queue + std::mutex + std::condition_variable 实现

下面是一个完整的线程安全队列实现示例:

立即学习C++免费学习笔记(深入)”;

#include 
#include 
#include 
#include 

template
class ThreadSafeQueue {
private:
    std::queue data_queue;
    mutable std::mutex mtx;
    std::condition_variable cv;

public:
    ThreadSafeQueue() = default;

    void push(T value) {
        std::lock_guard lock(mtx);
        data_queue.push(std::move(value));
        cv.notify_one(); // 唤醒一个等待的消费者
    }

    bool try_pop(T& value) {
        std::lock_guard lock(mtx);
        if (data_queue.empty()) {
            return false;
        }
        value = std::move(data_queue.front());
        data_queue.pop();
        return true;
    }

    void wait_and_pop(T& value) {
        std::unique_lock lock(mtx);
        cv.wait(lock, [this] { return !data_queue.empty(); });
        value = std::move(data_queue.front());
        data_queue.pop();
    }

    bool empty() const {
        std::lock_guard lock(mtx);
        return data_queue.empty();
    }

    size_t size() const {
        std::lock_guard lock(mtx);
        return data_queue.size();
    }
};

各方法说明与使用建议

push(T value):将元素加入队列。加锁后插入,并调用 notify_one() 唤醒一个正在等待的消费者线程。

try_pop(T& value):非阻塞尝试弹出元素。如果队列为空返回 false,否则赋值并返回 true。适合不想阻塞的场景。

wait_and_pop(T& value):阻塞式出队。若队列为空,则等待直到有元素可用。内部使用 unique_lock 配合条件变量实现高效等待。

empty() 和 size():提供只读查询功能。注意这些值可能在调用后立即变化,仅作参考。

使用示例:生产者-消费者模型

以下是一个简单的多线程测试例子:

#include 

void producer(ThreadSafeQueue& queue) {
    for (int i = 0; i < 5; ++i) {
        queue.push(i);
        std::this_thread::sleep_for(std::chrono::milliseconds(100));
    }
}

void consumer(ThreadSafeQueue& queue) {
    for (int i = 0; i < 5; ++i) {
        int value;
        queue.wait_and_pop(value);
        std::cout << "Consumed: " << value << '\n';
    }
}

int main() {
    ThreadSafeQueue queue;
    std::thread p(producer, std::ref(queue));
    std::thread c(consumer, std::ref(queue));

    p.join();
    c.join();

    return 0;
}

这个例子中,生产者每100ms放入一个数,消费者同步取出并打印。由于使用了条件变量,消费者不会占用CPU空转,而是被唤醒后处理数据。

基本上就这些。只要正确使用互斥锁保护共享状态,配合条件变量实现线程间通信,就能写出稳定高效的并发队列。实际项目中还可以扩展支持超时弹出(wait_for)、多消费者唤醒等特性。

相关专题

更多
treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

534

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

15

2026.01.06

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

21

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

13

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.9万人学习

C 教程
C 教程

共75课时 | 4.1万人学习

C++教程
C++教程

共115课时 | 12.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号