简单环形数组(缓冲区)实现

原文链接

#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define BUFF_MAX_LEN 16
#define VOS_OK 0
#define VOS_ERR -1

char *pHead = NULL;        //环形缓冲区首地址
char *pValidRead = NULL;   //已使用环形缓冲区首地址
char *pValidWrite = NULL;  //已使用环形缓冲区尾地址
char *pTail = NULL;        //环形缓冲区尾地址

//环形缓冲区初始化
void InitRingBuff() {
  if (NULL == pHead) {
    pHead = (char *)malloc(BUFF_MAX_LEN * sizeof(char));
  }

  memset(pHead, 0, sizeof(BUFF_MAX_LEN));

  pValidRead = pHead;
  pValidWrite = pHead;
  pTail = pHead + BUFF_MAX_LEN;
}

//环形缓冲区释放
void FreeRingBuff() {
  if (NULL != pHead) {
    free(pHead);
  }
}

//向缓冲区写数据
int WriteRingBuff(char *pBuff, int AddLen) {
  if (NULL == pHead) {
    printf("WriteRingBuff:RingBuff is not Init!\n");
    return VOS_ERR;
  }

  if (AddLen > pTail - pHead) {
    printf("WriteRingBuff:New add buff is too long\n");
    return VOS_ERR;
  }

  //若新增的数据长度大于写指针和尾指针之间的长度
  if (pValidWrite + AddLen > pTail) {
    int PreLen = pTail - pValidWrite;
    int LastLen = AddLen - PreLen;
    memcpy(pValidWrite, pBuff, PreLen);
    memcpy(pHead, pBuff + PreLen, LastLen);

    pValidWrite = pHead + LastLen;  //新环形缓冲区尾地址
  } else {
    memcpy(pValidWrite, pBuff, AddLen);  //将新数据内容添加到缓冲区
    pValidWrite += AddLen;               //新的有效数据尾地址
  }
  return VOS_OK;
}

//从缓冲区读数据
int ReadRingBuff(char *pBuff, int len) {
  if (NULL == pHead) {
    printf("ReadRingBuff:RingBuff is not Init!\n");
    return VOS_ERR;
  }
  if (len > pTail - pHead) {
    printf("ReadRingBuff:Read buff size is too long\n");
    return VOS_ERR;
  }
  if (0 == len) {
    return VOS_OK;
  }
  if (pValidRead + len > pTail) {
    int PreLen = pTail - pValidRead;
    int LastLen = len - PreLen;
    memcpy(pBuff, pValidRead, PreLen);
    memcpy(pBuff + PreLen, pHead, LastLen);

    pValidRead = pHead + LastLen;
  } else {
    memcpy(pBuff, pValidRead, len);
    pValidRead += len;
  }

  return len;
}

int main() {
  char c;
  int len;
  int readLen;
  char readBuffer[10];
  int i = 0;

  InitRingBuff();

  printf("Please enter a character\n");

  while (1) {
    c = getchar();

    switch (c) {
      case 'Q':
        goto exit;
        break;

      case 'R':
        readLen = ReadRingBuff(readBuffer, 10);
        printf("ReadRingBufflen:%d\n", readLen);
        if (readLen > 0) {
          for (i = 0; i < readLen; i++) {
            printf("%c ", (char)readBuffer[i]);
          }
          printf("\n");
        }
        break;

      default:
        if (c != '\n') WriteRingBuff((char *)&c, 1);
        break;
    }
  };

exit:
  FreeRingBuff();

  return 0;
}

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值