0

0

c++中如何使用数组实现环形缓冲区_c++数组环形缓冲区实现方法

下次还敢

下次还敢

发布时间:2025-09-26 15:04:02

|

771人浏览过

|

来源于php中文网

原创

答案:C++中环形缓冲区通过数组和读写索引实现高效数据流处理,利用取模运算使索引回绕,牺牲一个空间区分满和空状态,支持固定容量的先进先出存取,适用于嵌入式与生产者-消费者场景。

c++中如何使用数组实现环形缓冲区_c++数组环形缓冲区实现方法

在C++中,使用数组实现环形缓冲区(也叫循环队列)是一种高效处理固定大小数据流的方式,常用于嵌入式系统、网络通信和生产者-消费者场景。它的核心思想是利用数组的首尾相连结构,通过两个指针(或索引)来追踪读写位置,避免频繁内存分配与数据移动。

环形缓冲区的基本原理

环形缓冲区基于一个固定长度的数组,维护两个关键索引:

  • write_index(写指针):指向下一个可写入的位置
  • read_index(读指针):指向下一个可读取的数据位置

当索引到达数组末尾时,通过取模运算回到开头,实现“环形”效果。缓冲区为空时读指针等于写指针;为满时需特殊判断(通常牺牲一个空间避免歧义)。

基本实现步骤

下面是一个简洁的C++数组实现示例:

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

class CircularBuffer {
private:
    int* buffer;
    int capacity;
    int read_index;
    int write_index;
// 判断是否满(预留一个位置区分满和空)
bool isFull() const {
    return (write_index + 1) % capacity == read_index;
}

public: explicit CircularBuffer(int size) : capacity(size + 1), read_index(0), write_index(0) { buffer = new int[capacity]; }

~CircularBuffer() {
    delete[] buffer;
}

// 写入数据
bool push(int value) {
    if (isFull()) {
        return false; // 缓冲区满
    }
    buffer[write_index] = value;
    write_index = (write_index + 1) % capacity;
    return true;
}

// 读取数据
bool pop(int& value) {
    if (isEmpty()) {
        return false; // 缓冲区空
    }
    value = buffer[read_index];
    read_index = (read_index + 1) % capacity;
    return true;
}

// 判断是否为空
bool isEmpty() const {
    return read_index == write_index;
}

// 当前数据数量
int size() const {
    return (write_index - read_index + capacity) % capacity;
}

};

薏米AI
薏米AI

YMI.AI-快捷、高效的人工智能创作平台

下载

使用示例

你可以这样使用这个环形缓冲区:

int main() {
    CircularBuffer cb(5); // 实际可用4个元素
cb.push(10);
cb.push(20);
cb.push(30);

int val;
while (cb.pop(val)) {
    std::cout << val << " ";
}
// 输出:10 20 30
return 0;

}

关键注意事项

实现时需要注意以下几点:

  • 容量设计:实际分配的数组大小为用户容量+1,以便用一个空位区分满和空状态
  • 取模运算:确保索引回绕正确,(index + 1) % capacity 是标准做法
  • 线程安全:上述实现不支持多线程并发访问,如需在多线程环境使用,应添加互斥锁保护读写操作
  • 泛型扩展:可将int替换为模板参数,支持任意类型

基本上就这些。这种实现方式简单高效,适合大多数基础应用场景。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

318

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

538

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

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

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

481

2023.08.10

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

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

143

2025.12.24

linux是嵌入式系统吗
linux是嵌入式系统吗

linux是嵌入式系统,是一种用途广泛的系统软件,其特点是:1、linux系统是完全开放、免费的;2、linux操作系统的显著优势是多用户和多任务,保证了多个用户使用互不影响;3、设备是独立的,只要安装驱动程序,任何用户都可以对任意设备进行使用和操作。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2024.02.23

C++ 嵌入式系统开发入门与实践
C++ 嵌入式系统开发入门与实践

本专题将带你系统掌握 C++ 在嵌入式系统中的实战应用,内容覆盖硬件抽象、驱动开发、内存与性能优化、实时系统编程、跨平台编译构建,以及常用嵌入式框架与调试技巧,帮助开发者从零构建可运行于 MCU、ARM 等平台的高性能嵌入式项目。

209

2025.11.18

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

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

43

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号