STM32实现循环队列

1. 循环队列的核心结构设计

  • 数据结构定义:通常使用结构体封装队列的指针、长度及缓冲区。例如:

    cpp 复制代码
    typedef struct {
        u16 Head;     // 队头指针
        u16 Tail;     // 队尾指针
        u16 Length;   // 当前队列长度
        u8 Rsv_DAT[50]; // 缓冲区数组
    } ringbuff_t;

    其中,HeadTail通过模运算(如(Tail+1)%50)实现循环移动,避免越界。

  • 初始化函数:重置指针和长度:

    cpp 复制代码
    void ringbuff_init(ringbuff_t *q) {
        q->Head = q->Tail = q->Length = 0;
    }

2. 入队与出队操作

  • 入队(写入中断)​:在串口接收中断中将数据存入队列尾部:

    cpp 复制代码
    u8 write_ringbuff(u8 data) {
        if (q->Length >= 50) return FALSE; // 队列满
        q->Rsv_DAT[q->Tail] = data;
        q->Tail = (q->Tail + 1) % 50;
        q->Length++;
        return TRUE;
    }
  • 出队(主程序读取)​:从队头取出数据并处理:

    cpp 复制代码
    u8 read_ringbuff(u8 *rdata) {
        if (q->Length == 0) return FALSE; // 队列空
        *rdata = q->Rsv_DAT[q->Head];
        q->Head = (q->Head + 1) % 50;
        q->Length--;
        return TRUE;
    }

    需注意线程安全:若中断和主程序同时操作队列,需使用临界区或原子操作。


3. 队列状态判断与溢出处理

  • 队空条件Head == TailLength == 0
  • 队满条件(Tail + 1) % Size == Head,或通过Length判断。
  • 溢出处理
    • 动态扩容:部分实现支持缓冲区动态扩展(未在搜索结果中体现)。
    • 丢弃旧数据:当队列满时,可覆盖最旧数据或返回错误。

4. 实际应用场景

  • 串口通信 :在中断中接收数据并存入队列,主程序按协议解析。

    cpp 复制代码
    // 串口中断服务函数示例
    void USART1_IRQHandler() {
        u8 data = USART_ReceiveData(USART1);
        write_ringbuff(data); // 入队
    }
  • 多端口处理:支持多个接收端口(如双串口)的循环队列,需为每个端口分配独立队列。

  • 任务调度:将队列用于任务队列模式,管理异步任务执行。


5. 优化与扩展

  • 非阻塞设计:允许在中断中快速入队,主程序异步处理,避免阻塞。
  • 内存对齐:针对STM32的DMA传输,需确保缓冲区地址对齐。
  • 性能调优:通过调整缓冲区大小(如50→100)平衡内存占用与溢出风险。
相关推荐
偶像你挑的噻3 小时前
11-Linux驱动开发-I2C子系统–mpu6050简单数据透传驱动
linux·驱动开发·stm32·嵌入式硬件
Chat_zhanggong3455 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
强化学习与机器人控制仿真5 小时前
RSL-RL:开源人形机器人强化学习控制研究库
开发语言·人工智能·stm32·神经网络·机器人·强化学习·模仿学习
bai5459366 小时前
STM32 PWM驱动LED呼吸灯
stm32·单片机·嵌入式硬件
智者知已应修善业6 小时前
【51单片机普通延时奇偶灯切换】2023-4-4
c语言·经验分享·笔记·嵌入式硬件·51单片机
btzhy11 小时前
STM32单片机:基本定时器应用:单脉冲模式(STM32L4xx)
stm32·单片机·嵌入式硬件·基本定时器应用:单脉冲模式
文sir.13 小时前
温湿度采集系统(stm32+mqtt+Onenet云平台+esp8266)
stm32·单片机·嵌入式硬件·mqtt·onenet·云平台·esp8266
DIY机器人工房13 小时前
嵌入式面试题:你有没有用过直接基于TCP协议,不借助HTTP、MQTT这类上层协议的项目经历?
stm32·单片机·嵌入式硬件·面试题·diy机器人工房
zhmc15 小时前
Cortex M0单片机指令执行周期
单片机·嵌入式硬件
编程小白菜12315 小时前
STM32L051单片机485Ymode升级后程序不能正常运行问题
stm32·嵌入式硬件