0

0

c++如何使用std::atomic实现无锁队列_c++原子操作高级应用

穿越時空

穿越時空

发布时间:2025-12-02 16:11:33

|

625人浏览过

|

来源于php中文网

原创

答案:使用std::atomic实现无锁队列可提升高并发性能,其核心是通过原子操作管理头尾指针,利用compare_exchange_weak/strong保证入队出队的原子性,结合内存序控制与2的幂容量数组优化,避免锁竞争;链表实现需解决ABA问题,常用hazard pointer或RCU辅助;需注意平台支持、CAS失败率和内存序选择以确保效率与正确性。

c++如何使用std::atomic实现无锁队列_c++原子操作高级应用

在C++中,使用std::atomic实现无锁队列(lock-free queue)是原子操作的高级应用之一。无锁队列通过避免互斥锁来提升多线程环境下的性能,尤其适用于高并发场景。虽然实现起来比基于互斥量的队列复杂,但能有效减少线程阻塞和上下文切换。

基本原理与设计思路

无锁队列通常基于循环数组或链表结构实现。使用std::atomic保护关键状态(如头尾指针),确保多个线程可以安全地进行入队和出队操作而不加锁。

核心思想是:

  • 用两个原子变量分别表示队列的读位置(head)和写位置(tail)。
  • 入队时,原子地获取当前写位置并尝试更新;出队时类似。
  • 所有操作依赖compare_exchange_weakcompare_exchange_strong实现“比较-交换”逻辑,保证操作的原子性。

基于数组的无锁队列实现示例

以下是一个简化的固定大小的无锁队列实现:

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

#include 
#include 

template class LockFreeQueue { static_assert((Size & (Size - 1)) == 0, "Size must be power of 2");

std::arrayzuojiankuohaophpcnT, Sizeyoujiankuohaophpcn buffer_;
std::atomiczuojiankuohaophpcnsize_tyoujiankuohaophpcn head_ {0}; // 消费者修改
std::atomiczuojiankuohaophpcnsize_tyoujiankuohaophpcn tail_ {0}; // 生产者修改

public: bool enqueue(const T& item) { size_t currenttail = tail.load(std::memory_order_relaxed); size_t next_tail = (current_tail + 1) & (Size - 1);

    if (next_tail == head_.load(std::memory_order_acquire)) {
        return false; // 队列满
    }

    buffer_[current_tail] = item;
    tail_.store(next_tail, std::memory_order_release);
    return true;
}

bool dequeue(T& item) {
    size_t current_head = head_.load(std::memory_order_relaxed);
    if (current_head == tail_.load(std::memory_order_acquire)) {
        return false; // 队列空
    }

    item = buffer_[current_head];
    size_t next_head = (current_head + 1) & (Size - 1);
    head_.store(next_head, std::memory_order_release);
    return true;
}

};

说明:

PixVerse
PixVerse

PixVerse是一款强大的AI视频生成工具,可以轻松地将多种输入转化为令人惊叹的视频。

下载
  • 利用位运算& (Size - 1)代替取模,要求容量为2的幂次。
  • enqueue先检查是否满,再写入数据并更新tail_
  • dequeuehead_读取,并更新位置。
  • 内存序选择:loadacquirestorerelease,防止指令重排影响一致性。

链表式无锁队列的关键挑战

基于链表的无锁队列更灵活,但实现更复杂。主要难点包括:

  • A-B-A问题:一个节点被弹出后释放,又被重新分配并插入,导致CAS误判成功。
  • 需要使用std::atomic管理指针。
  • 推荐结合hazard pointerRCU机制来安全回收内存。

简单示意结构:

struct Node {
    T data;
    std::atomic next;
};

std::atomic> head; std::atomic> tail;

每次入队需原子地修改tail->nexttail指针,常采用双重CAS(DCAS)或使用标记指针(tagged pointer)解决ABA问题。

注意事项与性能建议

使用std::atomic实现无锁队列时应注意:

  • 并非所有平台都真正支持lock-free:可通过is_lock_free()检查。
  • 过度争用可能导致CAS频繁失败,反而降低性能。
  • 合理选择内存序(memory order),过强的顺序约束会削弱性能优势。
  • 避免在构造函数/析构函数中抛异常,否则资源管理会变得棘手。

基本上就这些。掌握std::atomic的正确使用,配合合理的数据结构设计,才能写出高效且正确的无锁队列。不复杂但容易忽略细节。

相关专题

更多
c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

524

2023.09.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

524

2023.09.20

treenode的用法
treenode的用法

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

534

2023.12.01

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

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

17

2025.12.22

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

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

16

2026.01.06

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

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

481

2023.08.10

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

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

143

2025.12.24

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

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

40

2026.01.16

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

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

62

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.7万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.9万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.4万人学习

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

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