A Macro Defined Ring Buffer(C Language)

本文深入探讨了RingBuffer(或FIFO)数据结构的关键特性,包括如何使用宏定义来初始化、读取和写入数据,以及如何计算其内部计数和检查是否为空或满。着重介绍了该数据结构在不同场景中的高效应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*******************************************************************************************\
* Ring Buffer(or FIFO)                                                                      *
* Caution: RING_BUF_SIZE must be 2^n                                                        *
\*******************************************************************************************/
#define RING_BUF_SIZE               (512)
#define RING_BUF_MASK               (RING_BUF_SIZE-1ul)
#define RING_BUF_RESET(rBuf)        (rBuf.rdIdx = rBuf.wrIdx = 0)
#define RING_BUF_WR(rBuf, dataIn)   (rBuf.data[RING_BUF_MASK & rBuf.wrIdx++] = (dataIn))
#define RING_BUF_RD(rBuf)           (rBuf.data[RING_BUF_MASK & rBuf.rdIdx++])
#define RING_BUF_COUNT(rBuf)        (RING_BUF_MASK & (rBuf.wrIdx - rBuf.rdIdx))
#define RING_BUF_EMPTY(rBuf)        (RING_BUF_COUNT(rBuf) == 0)
#define RING_BUF_FULL(rBuf)         (RING_BUF_COUNT(rBuf) == RING_BUF_MASK)

typedef struct __RING_BUF_T
{
  unsigned char data[RING_BUF_SIZE];
  unsigned int wrIdx;
  unsigned int rdIdx;
} RING_BUF_T;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值