C语言实现基于数组的环形缓冲队列

news2025/1/26 15:22:30

背景

在C语言编程场景中,常常需要对一段不定长数据进行缓存。这里提出一种基于数组的环形缓冲队列,解决上述场景的问题。

原理

如下图所示,首先定义数据长度为buf[8],初始化指针为in/out

其中in为缓冲数据的输入指针

out为缓冲数据的输出指针

缓存内写入一个数据

in++

如下图所示

缓存内读出一个数据

out++

如下图所示

这时判断in==out为true,所以表明缓存内没有数据。

如果把上述缓冲数组换成二维数组,代码可以编写如下

代码

buf_queue.c


/******************************************************************************
* 锟斤拷权锟斤拷锟斤拷 (c) 2009
*    
* 锟侥硷拷锟斤拷锟狡o拷queue.c
* 锟斤拷锟斤拷摘要锟斤拷锟斤拷锟斤拷通锟斤拷专锟矫伙拷锟斤拷循锟斤拷锟斤拷锟叫匡拷锟斤拷
* 锟斤拷 锟斤拷 锟脚o拷1.0
* 锟斤拷    锟竭o拷
* 锟斤拷锟斤拷锟斤拷冢锟�2012-01-01
*
* 锟睫改硷拷录1锟斤拷
* 锟睫革拷锟斤拷锟节o拷
* 锟斤拷 锟斤拷 锟脚o拷
* 锟斤拷 锟斤拷 锟剿o拷
* 锟睫革拷锟斤拷锟捷o拷
*******************************************************************************/

#include "buf_queue.h"
#include "stdio.h"
#include "string.h"

/******************************************************************************
*                                全锟街猴拷锟斤拷锟斤拷锟斤拷                                 *
******************************************************************************/
BUF_QUEUE bufQueue;


void InitQueue(BUF_QUEUE *pBufQueue)
{
    INT16U i;
    INT32U tmp;
    INT8U *p;
    p = (INT8U *)pBufQueue;
    tmp = sizeof(BUF_QUEUE) / sizeof(INT8U);
    for (i = 0; i < tmp; i++)
    {
        *p++ = 0;
    }
}

INT16U RxFromQueue(BUF_QUEUE *pBufQueue, INT8U *dst, INT16U len, INT8U *type)
{
    INT16U i;
    if (pBufQueue->In != pBufQueue->Out)
    {
		for(i = 0; i < len; i++)
		{
			*(dst + i) = pBufQueue->datBuf[pBufQueue->Out].buf[i];
		}
		*type = pBufQueue->datBuf[pBufQueue->Out].buf_type;
        pBufQueue->Out++;
        pBufQueue->Out &= (RX_SIZE_LEN-1);
        return 0;
    }
    return 1;
}

INT16U WxToQueue(BUF_QUEUE *pBufQueue, INT8U *dat, INT16U len, INT8U type)
{
    INT16U tmp, i;
    tmp = (pBufQueue->In+1) & (RX_SIZE_LEN-1);
    if (tmp != pBufQueue->Out)
    {
    	memset(pBufQueue->datBuf[pBufQueue->In].buf, 0, sizeof(pBufQueue->datBuf[pBufQueue->In].buf));
		for(i = 0; i < len; i++)
		{
			pBufQueue->datBuf[pBufQueue->In].buf[i] = *(dat + i);
		}
		pBufQueue->datBuf[pBufQueue->In].buf_type = type;
        pBufQueue->In++;
        pBufQueue->In &= (RX_SIZE_LEN - 1);
        return 0;
    }
    return 1;//
}
void clearQueue(BUF_QUEUE *pBufQueue)
{
	InitQueue(pBufQueue);
}
//---------------------------------------------------------------------------


buf_queue.h


/******************************************************************************
*   锟斤拷权锟斤拷锟斤拷(c) 2013
*    
*   锟侥硷拷锟斤拷锟狡o拷queue.h
*   锟斤拷锟斤拷摘要锟斤拷锟斤拷锟斤拷专锟矫伙拷锟斤拷锟斤拷锟�
*   锟斤拷锟斤拷说锟斤拷锟斤拷
*   锟斤拷 锟斤拷 锟脚o拷V1.0.0.0
*   锟斤拷    锟竭o拷
*   锟斤拷锟斤拷锟斤拷冢锟�
*
*   锟睫改硷拷录锟斤拷
*   锟睫革拷锟斤拷锟节o拷
*   锟斤拷 锟斤拷 锟脚o拷
*   锟斤拷 锟斤拷 锟剿o拷
*   锟睫革拷锟斤拷锟捷o拷
******************************************************************************/
#ifndef _DEF_QUEUE_CLASS_H_
#define _DEF_QUEUE_CLASS_H_

/******************************************************************************
*                          锟斤拷锟斤拷锟斤拷头锟侥硷拷                                       *
******************************************************************************/
#include "stm32f4xx_hal.h"
#include "common.h"

/******************************************************************************
*                          锟疥定锟斤拷                                             *
******************************************************************************/
#define RX_SIZE_LEN           32
#define MAX_BUF_LEN           100
#define BUF_TYPE_FROM_NB      1
#define BUF_TYPE_FROM_SENSOR  2


/******************************************************************************
*                          锟斤拷锟斤拷锟斤拷锟酵讹拷锟斤拷                                       *
******************************************************************************/
typedef struct 
{
	INT8U  buf_type;
    INT8U  buf[MAX_BUF_LEN];
} DAT_BUF;
// 锟斤拷锟秸凤拷锟斤拷锟街节讹拷锟斤拷
typedef struct 
{
    INT16U In;
    INT16U Out;
    DAT_BUF datBuf[RX_SIZE_LEN];
} BUF_QUEUE;

/******************************************************************************
*                          锟解部锟斤拷锟斤拷锟斤拷锟斤拷                                       *
******************************************************************************/
// 锟斤拷始锟斤拷锟斤拷锟斤拷
extern void   InitQueue(BUF_QUEUE *pBufQueue);
extern INT16U RxFromQueue(BUF_QUEUE *pBufQueue, INT8U *dst, INT16U len, INT8U *type);
extern INT16U WxToQueue(BUF_QUEUE *pBufQueue, INT8U *dat, INT16U len, INT8U type);
extern void   clearQueue(BUF_QUEUE *pBufQueue);
extern BUF_QUEUE bufQueue;

#endif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/924292.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智慧党建VR虚拟3D数字化展厅发展和传承传统文化

三维全景虚拟现实技术应用在虚拟展馆中&#xff0c;主要是通过全景照片的虚拟与建模&#xff0c;营造出三维虚拟仿真的场景&#xff0c;从而结合展馆展示的需求&#xff0c;营造出更加有效的氛围&#xff0c;起到优化展示效果的作用。 三维全景虚拟现实技术的应用&#xff0c;能…

记录:yolov8训练自己的数据集

一、LabelImg标注自己的原图数据集 .xml标注格式 二、带标签的数据增强 先将原始数据&#xff08;图片&#xff0c;标注&#xff09;转移到项目根目录&#xff0c;然后再数据增强&#xff0c;避免标注内容路径错误。 亮度变换加旋转 # 一、亮度 img_dir multi/images # 原始…

科研论文配图绘制指南——基于Python—第二章2.seaborn

目录 第二章2.2 Seaborn2.2.2 多子图网格型图2.2.3 绘图风格、颜色主题和绘图元素缩放比例 第二章 2.2 Seaborn Seaborn是Python中一个非常受用户欢迎的可视化库。Seaborn 在 Matplotlib 的基础上进行了更加高级的封装&#xff0c;用户能够使用极少的代码绘制出拥有丰富统计信…

线程的生命周期详解

一个线程的生命周期有6个阶段&#xff1a; 新建&#xff0c;是刚使用new方法&#xff0c;new出来的线程&#xff1b;就绪&#xff0c;是调用的线程的start()方法后&#xff0c;这时候线程处于等待CPU分配资源阶段&#xff1b;运行&#xff0c;当就绪的线程被调度并获得CPU资源时…

【第三阶段】kotlin语言的内置函数takeif

package Stage3fun main() {println(checkPermission("root","123")) }//检查校验 //username.takeif{true/false} true:返回username本身 false:返回nullfun checkPermission(userame:String,pwd:String):String{return userame.takeIf { permissionSy…

linux————Keepalived—web双机热备

一、概述 Keepalived 是一个基于 VRRP 协议来实现的 LVS 服务高可用方案&#xff0c;可以解决静态路由出现的单点故障问题。 原理 在一个 LVS 服务集群中通常有主服务器&#xff08;MASTER&#xff09;和备份服务器&#xff08;BACKUP&#xff09;两种角色的服务器&#xff0c…

线索二叉树——找前驱、后继

前言 一个二叉树被线索化之后&#xff0c;一个节点的前驱或后继会存在两种情况&#xff0c; 1、tag1&#xff0c;有明确的线索化前驱或后继&#xff0c; 2、tag0&#xff0c;只存在左右孩子&#xff0c;但是没用明确的线索化前驱后继&#xff0c;需要分析 //线索二叉树结点定义…

类的加载过程三:initialization

1、类的加载初始化 初始化阶段就是执行类构造器方法<clinit>()的过程。此方法不需要定义&#xff0c;是javac编译器自动收集类中的所有 类变量 的赋值动作和 静态代码块 中的语句合并而来。 构造器方法中指令按语句在源文件中出现的顺序执行。 package com.jvm.java;pub…

SpringIoC组件的高级特性

目录 一、Bean组件的周期与作用域 二、FactoryBean接口 一、Bean组件的周期与作用域 1.1 Bean组件的生命周期 什么是Bean的周期方法 我们可以在组件类中定义方法&#xff0c;然后当IoC容器实例化和销毁组件对象的时候进行调用&#xff01;这两个方法我们成为生命周期方法&a…

并行矩阵乘法(C++ mpi 并行实现)

矩阵乘法有2种思路&#xff0c;我最先想到的是第一种思路&#xff0c;但是时间、空间复杂度都比较高。后面参考了一些资料&#xff0c;实现了第二种思路。 一、思路1&#xff1a;按行、列分块 矩阵乘法有一个很好的性质&#xff0c;就是结果矩阵的每个元素是不互相依赖的&…

如何快速开发一个软件?这篇文章讲明白了

在当今快节奏的数字化世界中&#xff0c;软件开发已成为企业和个人必不可少的一环。然而&#xff0c;传统的软件开发流程往往耗时费力&#xff0c;需要大量的编码和测试工作。幸运的是&#xff0c;现代技术已经带来了许多创新的方式来加速软件开发过程。其中&#xff0c;利用简…

使用ChatGPT创造商业价值变现的思路 | 纯分享

​ 谷歌的Bard和OpenAI的ChatGPT等人工智能工具风靡全球。尽管关于AI如何以及是否应该被广泛使用&#xff0c;甚至关于它们是否真正具有“智能”这一说法&#xff0c;仍存在许多争议和激烈的讨论&#xff0c;但是这些工具早已潜移默化地出现在我们身边。 最大的原因之一在于这…

总结:Git 撤销操作

1、还未添加到暂存区&#xff1a;git checkout -- filename 执行命令后&#xff0c;会回退到未修改之前的状态 2、已经添加到暂存区&#xff1a;git reset HEAD filename 执行命令后&#xff0c;会回退到工作区之前的状态 3、已经 commit&#xff0c;但是还未 push git reset…

lab6 cow

task cow的目标就是延迟分配&#xff0c;并且直到必须要复制的时候才会分配物理内存 cow的fork只为child创造了一个页表&#xff0c;其中的PTE指向了父进程的物理页面cow的fork将父进程和孩子进程的用户态的PTE都标记为不可写当某个进程想要去写一个cow的页面时&#xff0c;c…

MyBatis 框架的搭建及使用

目录 什么是 MyBatisMyBatis 环境的搭建添加 MyBatis 依赖设置 MyBatis 配置 根据 MyBatis 写法完成数据库操作查询操作(无参)定义接口使用 XML 实现接口类中的属性名与数据库表中字段名不一致怎么办 ? 查询操作(有参)${} 和 #{} 有啥区别 ?使用 ${} 会出现的问题like 查询 删…

CypherRAT、CraxsRATAndroid系列恶意软件“始作俑者”曝光!

近日&#xff0c;恶意软件系列 CypherRAT 和 CraxsRAT 的创建者曝光&#xff0c;是一位名为 EVLF 的叙利亚威胁行为者。 网络安全公司Cyfirma在上周发布的一份报告中提到&#xff1a;这些RAT旨在允许攻击者远程执行实时操作&#xff0c;并控制受害者设备的摄像头、位置和麦克风…

职场的心灵疗愈:如何战胜压力与燃尽?

职场压力的根源 当代职场的变革与挑战 在数字化时代,职场的变革速度前所未有。新的技术和工具不断涌现,要求员工持续学习和适应。例如,云计算、大数据和人工智能等技术正在改变许多行业的工作方式。这些技术为我们带来了便利,但同时也带来了学习和适应的压力。 此外,全球…

keepalived+lvs(DR)(四十六)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、作用 二、调度器配置 三、web节点配置 一、作用 使用keepalived解决lvs的单点故障 高可用集群 二、调度器配置 安装keepalived yum install -y k…

leetcode:电话号码的字母组合(详解)

题目 给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例 1&#xff1a; 输入&#xff1a;digits "23" 输出…

基于javaweb的新生报到系统

摘 要 随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理系统应运而生&#xff0c;各行各业相继进入信息管理时代&…