0

0

c++怎么实现一个无锁的环形缓冲区_C++高性能数据结构与无锁编程

尼克

尼克

发布时间:2025-11-13 22:18:07

|

921人浏览过

|

来源于php中文网

原创

无锁环形缓冲区通过原子操作和内存序控制实现线程安全,使用std::atomic管理读写索引,数组大小为2的幂以位运算优化取模,push和pop分别用memory_order_release与acquire保证可见性与顺序,适用于SPSC高吞吐场景,MPMC需更复杂机制。

c++怎么实现一个无锁的环形缓冲区_c++高性能数据结构与无锁编程

实现一个无锁的环形缓冲区(Lock-Free Ring Buffer)关键在于避免使用互斥锁,转而依赖原子操作和内存序控制来保证线程安全。这种结构在高性能场景中非常有用,比如高吞吐的日志系统、实时通信或音视频处理。

核心设计思路

无锁环形缓冲区通常基于固定大小的数组实现,维护两个指针:生产者(写)索引和消费者(读)索引。通过原子操作更新这两个索引,避免多线程竞争导致的阻塞。

要点如下:

  • 使用 std::atomic 来保护读写位置
  • 确保数组大小为 2 的幂,便于用位运算取模
  • 正确设置内存序(memory order),平衡性能与可见性
  • 避免 ABA 问题和伪共享(cache line padding)

基础结构定义

template
class LockFreeRingBuffer {
    static_assert((Size & (Size - 1)) == 0, "Size must be power of 2");
std::arrayzuojiankuohaophpcnT, Sizeyoujiankuohaophpcn buffer_;
std::atomiczuojiankuohaophpcnsize_tyoujiankuohaophpcn write_index_{0};
std::atomiczuojiankuohaophpcnsize_tyoujiankuohaophpcn read_index_{0};

public: bool push(const T& item) { size_t current_write = writeindex.load(std::memory_order_relaxed); size_t next_write = (current_write + 1) & (Size - 1);

    if (next_write == read_index_.load(std::memory_order_acquire)) {
        return false; // 已满
    }

    buffer_[current_write] = item;
    write_index_.store(next_write, std::memory_order_release);
    return true;
}

bool pop(T& item) {
    size_t current_read = read_index_.load(std::memory_order_relaxed);
    if (current_read == write_index_.load(std::memory_order_acquire)) {
        return false; // 已空
    }

    item = buffer_[current_read];
    size_t next_read = (current_read + 1) & (Size - 1);
    read_index_.store(next_read, std::memory_order_release);
    return true;
}

};

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

Moshi Chat
Moshi Chat

法国AI实验室Kyutai推出的端到端实时多模态AI语音模型,具备听、说、看的能力,不仅可以实时收听,还能进行自然对话。

下载

内存序的选择

内存序对性能和正确性至关重要:

  • load(std::memory_order_acquire):确保后续读操作不会重排到该加载之前
  • store(std::memory_order_release):确保前面的写操作不会重排到该存储之后
  • relaxed 模式:仅用于无同步需求的计数类操作

在单生产者单消费者(SPSC)场景下,acquire/release 足够;多生产者或多消费者需要更复杂的同步逻辑,可能需引入 seq_cst 或额外机制。

适用场景与限制

这种实现最适合 SPSC 场景。MPMC(多生产多消费)需要更复杂的 CAS 循环或专用算法(如 Dmitry Vyukov 的无锁队列思想)。

  • 优点:无锁、低延迟、高吞吐
  • 缺点:容量固定、调试困难、MPMC 实现复杂
  • 注意:元素类型 T 应为 trivially copyable,避免析构问题

基本上就这些。只要理解原子操作和内存模型,无锁环形缓冲区并不复杂但容易忽略细节。实际使用前建议加上单元测试验证并发行为。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

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

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

519

2023.09.20

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

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

519

2023.09.20

treenode的用法
treenode的用法

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

529

2023.12.01

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

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

6

2025.12.22

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

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

471

2023.08.10

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

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

107

2025.12.24

css中的padding属性作用
css中的padding属性作用

在CSS中,padding属性用于设置元素的内边距。想了解更多padding的相关内容,可以阅读本专题下面的文章。

128

2023.12.07

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

388

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

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

精品课程

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

共94课时 | 5.7万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.6万人学习

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

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