C语言实现一个缓冲区-FIFO(食堂干饭版)

原创 云深之无迹 2025-03-19 00:38
FIFO(First In, First Out,先进先出队列)可以想象成一个 排队打饭 的场景,最先排队的人最先打到饭,后面来的人只能排在后面。
FIFO 里两个最重要的“指针”
  1. 写指针(write_index)负责存数据,就像打饭的窗口,给排队的人装饭。
  2. 读指针(read_index) 负责取数据,就像学生排队领饭,最先排队的最先拿到饭。

数据写入 FIFO(打饭窗口装饭)
每次有新的数据(饭),就存入 FIFO(放在队伍的最后)。写指针 write_index 向前移动,表示新的数据存进来了。如果饭盒满了(FIFO 满),就不能再装饭了,得等人先吃(读取数据)。
数据读取 FIFO(学生排队打饭)
FIFO 里有数据时,读指针 read_index 取出最早存入的数据。
取完数据后,读指针向前移动,准备读取下一个数据。如果队伍里没人(FIFO 为空),就没数据可读了!
FIFO 什么时候需要清空?
如果打饭的学生全都吃完了,队伍为空(FIFO 为空),指针会指向同一个位置。如果不清理饭盒(FIFO 满了),就不能继续装饭(写入新数据),需要“清空”队伍重新开始。
在程序里,我们可以用 fifo_flush() 来清空 FIFO,重置指针。
typedef struct {    uint8_t buffer[256];  // 存放数据(饭盒)    uint16_t write_index;  // 写入指针(打饭窗口)    uint16_t read_index;   // 读取指针(学生排队领饭)    uint16_t count;        // 当前存放了多少数据(队伍长度)} FIFO_t;
  1. buffer[256]就是 256 个饭盒,用来存数据。

  2. write_index负责装饭(存数据)。

  3. read_index负责拿饭(取数据)。

  4. count记录当前队伍里有多少人(存了多少数据)。


void fifo_init(FIFO_t *fifo) {    fifo->write_index = 0;    fifo->read_index = 0;    fifo->count = 0;}

刚开始都清0

bool fifo_write(FIFO_t *fifo, uint8_t data) {    if (fifo->count == 256return false;  // 饭盒满了,不能再存数据    fifo->buffer[fifo->write_index] = data;  // 把数据存入 FIFO    fifo->write_index = (fifo->write_index + 1) % 256;  // 环形队列    fifo->count++;    return true;}

这里唯一的难点就是环形的概念

一个 钟表(时钟),指针一直顺时针转,到了 12 点不会变成 13 点,而是重新回到 1 点。
FIFO 的 write_index 就像钟表的指针:如果当前 write_index = 255,下一个写入位置不是 256,而是回到 0(重新开始)。这样就能一直循环存数据,不会超出数组范围。
正常递增
write_index = 5;write_index = (write_index + 1) % 256;  // 变成 6
FIFO 快到末尾
write_index = 254;write_index = (write_index + 1) % 256;  // 变成 255
FIFO 到达最大索引
write_index = 255;write_index = (write_index + 1) % 256;  // 变成 0(回到起点)
这样 FIFO 不会溢出,保证数据始终在 0 ~ 255 之间循环。

检查 FIFO 是否满了(饭盒是否装满了),满了就不能再写入。

写入数据后,写指针 write_index 往前移动,到下一个空位。队伍人数 count++,表示数据增加了。

bool fifo_read(FIFO_t *fifo, uint8_t *data) {    if (fifo->count == 0return false;  // 队伍没人,无法取数据    *data = fifo->buffer[fifo->read_index];  // 取出 FIFO 里的数据    fifo->read_index = (fifo->read_index + 1) % 256;  // 环形队列    fifo->count--;    return true;}

如果 FIFO 为空,说明没人排队,无法取数据。

读取 FIFO 里的数据(拿饭),读指针 read_index 往前走。

队伍人数 count--,说明数据减少了。

int main() {    FIFO_t fifo;    fifo_init(&fifo);    // 写入数据    fifo_write(&fifo, 10);      fifo_write(&fifo, 20);      fifo_write(&fifo, 30);      // 读取数据    uint8_t value;    while (fifo_read(&fifo, &value)) {        printf("取出的数据: %d\n", value);    }    return 0;}

FIFO 就像一个排队取饭的过程,先进的先出!

写指针(write_index) 负责存数据,数据存完后指针往前走。
读指针(read_index) 负责取数据,数据取完后指针往前走。
队伍满了(FIFO 满) 就不能再写入,必须先读取。
队伍没人(FIFO 空) 就不能读取,必须先写入数据。

评论 (0)
  • 流感季急诊室外彻夜排起的长队,手机屏幕里不断闪烁的重症数据,深夜此起彼伏的剧烈咳嗽声——当病毒以更狡猾的姿态席卷全球,守护健康的战争早已从医院前移到每个人的身上。在医学界公认的「72小时黄金预警期」里,可穿戴设备闪烁的光芒正穿透皮肤组织,持续捕捉血氧浓度、心率变异性和体温波动数据。这不是科幻电影的末日警报,而是光电传感器发出的生命预警,当体温监测精度精确到±0.0℃,当动态血氧检测突破运动伪影干扰……科技正在重新定义健康监护的时空边界。从智能手表到耳机,再到智能戒指和智能衣物,这些小巧的设备通过
    艾迈斯欧司朗 2025-03-20 15:45 129浏览
  • 如同任何对我们工作方式的改变,新的工作方式必然会遇到许多必须面对的挑战。如果不解决组织在实施精益六西格玛过程中面临的障碍以及如何克服它们的问题,那么关于精益六西格玛的讨论就不算完整。以下列举了组织在成功实施精益六西格玛时常见的几个障碍,以及克服它们的方法:1)对精益六西格玛方法论缺乏理解。抵触情绪通常源于对精益六西格玛方法论的不了解,以及不相信它能真正发挥作用。这种情况在所有层级的人员中都会出现,包括管理层。虽然教育培训可以帮助改善这一问题,但成功的项目往往是打消疑虑的最佳方式。归根结底,这是一
    优思学院 2025-03-20 12:35 78浏览
  • 贞光科技代理的品牌-光颉科技高精密薄膜电阻凭借0.01%的超高精度,在AI服务器电源模块中实现了精确电压分配、优化功率因数和减少热损耗,显著提升系统能效和可靠性。在当今的数字时代,人工智能(AI)服务器已成为数据中心的核心。随着AI应用的激增,服务器的性能和能效需求也在不断提高。电源模块作为服务器的关键组件,其性能直接影响整个系统的效率和可靠性。本文将探讨光颉科技高精密薄膜电阻,特别是其0.01%的精度,如何在AI服务器电源模块中提升能效。电源模块在AI服务器中的重要性电源模块负责将输入电源转换
    贞光科技 2025-03-20 16:55 112浏览
  • 故障现象 一辆2024款路虎发现运动版车,搭载2.0 L发动机,累计行驶里程约为5 000 km。车主反映,使用遥控器无法解锁车门,随后使用机械钥匙打开车门,踩下制动踏板,按压起动按钮,仪表盘提示“将智能钥匙放在图示位置,然后按下起动按钮”(图1)。 图1 故障车的仪表盘提示采用上述应急起动方法,发动机能够起动着机。上述故障现象已出现过多次,过一段时间又会恢复正常,这次故障出现要求将车辆拖入店内进行彻底检修。 故障诊断 车辆进店后进行试车,车辆一切功能又恢复正常。经过反复测试
    虹科Pico汽车示波器 2025-03-20 10:17 57浏览
  • 在电子制造领域,PCB(印刷电路板)的使用寿命直接决定了产品的长期稳定性和可靠性。捷多邦作为全球领先的PCB制造商,始终将质量放在首位,致力于为客户提供高可靠性、高性能的PCB解决方案。以下是捷多邦如何确保PCB使用寿命超过20年的核心技术与优势。 1. ​高品质原材料:从源头保障耐用性捷多邦采用国际认证的优质基材,如FR4、高频材料和高TG板材,确保PCB在高温、高湿等极端环境下的稳定性。通过严格的原材料筛选和入库检验,捷多邦从源头控制质量,避免因材料缺陷导致的失效问题。 
    捷多邦 2025-03-20 11:22 92浏览
  • 4月8-11日,第91届中国国际医疗器械博览会(CMEF)将在国家会展中心(上海)举办。这场全球瞩目的医疗科技盛宴以“创新科技,智领未来”为主题,旨在全方位展示医疗科技的最新成果,与来自全球的行业同仁一道,为全球医疗健康领域带来一场科技与商贸交融的产业“盛宴”。飞凌嵌入式作为专业的嵌入式技术解决方案提供商,一直致力于为医疗器械行业提供丰富的、高可靠性的嵌入式硬件主控解决方案。届时,飞凌嵌入式将为来自全球的观众带来适用于IVD、医疗影像、生命体征监测等医疗设备的嵌入式板卡、显控一体屏产品以及多款动
    飞凌嵌入式 2025-03-20 11:46 33浏览
  •         在当今电子设备高度集成的时代,电路保护显得尤为重要。TVS管(瞬态电压抑制二极管)和压敏电阻作为一种高效的电路保护器件,被广泛应用于各种电子设备中,用以吸收突波,抑制瞬态过电压,从而保护后续电路免受损坏。而箝位电压,作为TVS管和压敏电阻的核心参数之一,直接关系到其保护性能的优劣。箝位电压的定义        箝位电压指瞬态保护器件(如TVS二极管、压敏电阻)在遭遇过压时,将电路电压限制在安全范围内的
    广电计量 2025-03-20 14:05 71浏览
  • 本文内容来自微信公众号【工程师进阶笔记】,以工程师的第一视角分析了飞凌嵌入式OK3506J-S开发板的产品优势,感谢原作者温老师的专业分享。前两周,有一位老朋友联系我,他想找人开发一款数据采集器,用来采集工业现场的设备数据,并且可以根据不同的业务场景,通过不同的接口把这些数据分发出去。我把他提的需求总结了一下,这款产品方案大概有以下功能接口,妥妥地一款工业网关,在网上也能找到很多类似的产品方案,为啥他不直接买来用?再跟朋友深入地聊了一下,他之所以联系我,是因为看到我在公众号介绍过一款由飞凌嵌入式
    飞凌嵌入式 2025-03-20 11:51 102浏览
  • 全球领先的光学解决方案供应商艾迈斯欧司朗(SIX:AMS)近日宣布,凭借AS1163独立智能驱动器(SAID)成为中国领先的智能集成系统产品汽车制造商宁波福尔达智能科技股份有限公司(“福尔达”)环境动态照明应用的关键供应商。此次合作标志着汽车技术发展的一个重要时刻,充分展现了AS1163在优化动态照明应用系统成本方面的多功能性和先进性能。该产品支持传感器集成,拥有专为车顶照明设计的超薄外形,并能提升车内照明系统的性能。AS1163是一款先进的智能LED驱动器,能够与开放系统协议(OSP)网络无缝
    艾迈斯欧司朗 2025-03-20 14:26 73浏览
  • 在人工智能与物联网技术深度融合的今天,离线语音识别技术凭借其隐私安全、即时响应等优势,正在智能家居、工业控制等领域快速普及。广州唯创电子推出的WTK6900系列语音识别芯片,凭借其创新的离线命令词自学习功能,为用户提供了灵活高效的语音交互解决方案。本文将深入解析这一核心技术的工作原理及操作流程。一、智能自学习功能概述WTK6900系列芯片支持多模态学习方式,用户可通过物理按键、串口指令、语音命令或专用APP启动学习流程。其核心技术突破在于:全离线运行:所有学习过程均在本地完成,无需网络传输动态模
    广州唯创电子 2025-03-20 08:54 142浏览
  • 近日,保定飞凌嵌入式技术有限公司(以下简称“飞凌嵌入式”)携手瑞芯微电子股份有限公司(以下简称“瑞芯微”)正式加入2025年全国大学生嵌入式芯片与系统设计竞赛(以下简称“嵌入式大赛”),并在应用赛道中设立专属赛题。本次嵌入式大赛,双方选用基于瑞芯微RK3588芯片设计的ELF 2开发板作为参赛平台,旨在通过此次合作,促进产教融合,共同推动嵌入式系统创新人才的培养。全国大学生嵌入式芯片与系统设计竞赛是一项A类电子设计竞赛,同时也是被教育部列入白名单的赛事,由中国电子学会主办,是学生保研、求职的公认
    飞凌嵌入式 2025-03-20 11:53 62浏览
  • 为有效降低人为疏失导致交通事故发生的发生率,各大汽车制造厂及系统厂近年来持续开发「先进驾驶辅助系统」ADAS, Advanced Driver Assistance Systems。在众多车辆安全辅助系统之中,「紧急刹车辅助系统」功能(AEB, Autonomous Emergency Braking)对于行车安全性的提升便有着相当大的帮助。AEB透过镜头影像模块与毫米波雷达感测前方目标,可在发生碰撞前警示或自动刹车以降低车辆损伤以及乘员伤害。面临的挑战以本次分享的客户个案为例,该车厂客户预计在
    百佳泰测试实验室 2025-03-20 15:07 71浏览
  • 家电“以旧换新”政策的覆盖范围已从传统的八大类家电(冰箱、洗衣机、电视、空调、电脑、热水器、家用灶具、吸油烟机)扩展至各地根据本地特色和需求定制的“8+N”新品类。这一政策的补贴再叠加各大电商平台的优惠,家电销售规模显著增长,消费潜力得到进一步释放。晶尊微方案为升级换代的智能家电提供了高效且稳定的触摸感应和水位检测功能,使得操作更加便捷和可靠!主要体现在:水位检测1健康家电:养生壶、温奶器、加湿器的缺水保护安全2清洁电器:洗地机、扫地机器人的低液位和溢液提醒3宠物家电:宠物饮水机的缺水提醒/满水
    ICMAN 2025-03-20 15:23 106浏览
  • PCIe 5.0应用环境逐步成形,潜在风险却蠢蠢欲动?随着人工智能、云端运算蓬勃发展,系统对于高速数据传输的需求不断上升,PCI Express(PCIe)成为服务器应用最广的传输技术,尤其在高效能运算HPC(High Performance Computing)及AI服务器几乎皆导入了最新的PCIe 5.0规格,使得数据传输的双向吞吐量达到了128GB/s,让这两类的服务器能够发挥最大的效能。不过随着PCIe 5.0的频率达到16GHz,PCB板因为高频而导致讯号衰减加剧的特性,使得厂商面临很
    百佳泰测试实验室 2025-03-20 13:47 69浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦