0

0

c++怎么实现一个线程安全的队列_c++多线程安全容器设计

冰火之心

冰火之心

发布时间:2025-11-08 22:38:02

|

732人浏览过

|

来源于php中文网

原创

线程安全队列通过std::mutex和std::condition_variable实现,确保多线程下push和pop操作的原子性与阻塞等待,适用于生产者-消费者模型。

c++怎么实现一个线程安全的队列_c++多线程安全容器设计

在C++多线程编程中,实现一个线程安全的队列是常见需求,比如用于生产者-消费者模型。要保证多个线程同时访问队列时不会出现数据竞争或状态不一致,必须使用同步机制。下面介绍一种基于std::queuestd::mutexstd::condition_variable的安全队列实现方式。

基本设计思路

线程安全队列的核心目标是:多个线程可以安全地入队(push)和出队(pop),包括阻塞等待机制以提高效率。

关键点:

  • 使用std::mutex保护对内部队列的访问
  • 使用std::condition_variable实现线程等待非空/非满状态
  • 提供pushpop操作的原子性与阻塞性

代码实现示例

#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(); // 唤醒一个等待的pop线程
    }

    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();
    }
};

使用场景说明

这个队列适合大多数多线程协作场景:

造次
造次

Liblib打造的AI原创IP视频创作社区

下载

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

  • 生产者线程调用push()添加任务
  • 消费者线程调用wait_and_pop()阻塞等待新任务
  • 若不想阻塞,可用try_pop()尝试获取元素

例如:

ThreadSafeQueue task_queue;

// 生产者
auto producer = [&]() {
    for (int i = 0; i < 5; ++i) {
        task_queue.push(i);
        std::this_thread::sleep_for(std::chrono::milliseconds(100));
    }
};

// 消费者
auto consumer = [&]() {
    int value;
    for (int i = 0; i < 5; ++i) {
        task_queue.wait_and_pop(value);
        std::cout << "Consumed: " << value << "\n";
    }
};

std::thread t1(producer);
std::thread t2(consumer);
t1.join(); t2.join();

注意事项与优化方向

虽然上述实现已满足基本线程安全需求,但仍有几点需要注意:

  • 频繁加锁可能影响性能,可考虑无锁队列(如使用CAS操作)用于高并发场景
  • 当前版本未支持超时弹出(如wait_forwait_until),可根据需要扩展
  • 若需限制队列容量,可在push中加入等待非满逻辑
  • 注意异常安全:确保所有路径都正确释放锁
基本上就这些。这个设计简洁实用,适用于大多数C++多线程项目中的任务调度或消息传递。

相关专题

更多
线程和进程的区别
线程和进程的区别

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

481

2023.08.10

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

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

143

2025.12.24

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

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

72

2026.01.16

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

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

131

2026.01.16

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

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

54

2026.01.16

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

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

39

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

19

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

85

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

43

2026.01.15

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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