FreeRTOS学习笔记>信号量

信号量(Semaphore)是FreeRTOS中一种常用的同步机制,用于管理多个任务之间的访问资源的控制。

信号量(Semaphore)是一种实现任务间通信的机制,可以实现任务之间同步或临界资源的互斥访问,常用于协助一组相互竞争的任务来访问临界资源。在多任务系统中,各任务之间需要同步或互斥实现临界资源的保护。

信号量可以分为二进制信号量和计数信号量:

  1. 二进制信号量 :
    • 只有两个状态:有信号和无信号。
    • 常用于实现简单的任务同步和互斥锁。
  2. 计数信号量 :
    • 可以有多个信号,用于管理多个相同资源的访问。
    • 适用于资源数量有限的场景,比如一组相同类型的硬件外设。
  3. 互斥信号量:
    • 也被称为互斥锁(Mutex),用于保护共享资源,确保同一时间只有一个任务可以访问该资源。
    • 互斥信号量有优先级继承机制,避免任务优先级反转问题。
  4. 递归信号量:
    • 允许同一任务多次获得信号量,而不导致死锁。
    • 适用于需要递归访问资源的场景。

信号量的创建和使用

  • 创建信号量:

    复制代码
    //创建二值信号量
    SemaphoreHandle_t xSemaphore = xSemaphoreCreateBinary();
    
    /*********
    * 创建计数信号量
    * 计数信号量的最大值
    * 创建计数信号量的初始值
    **********/
    SemaphoreHandle_t xSemaphore = xSemaphoreCreateCounting(5,5);
  • 获取信号量:

    复制代码
    if (xSemaphoreTake(xSemaphore, (TickType_t) 10) == pdTRUE) {
        // 成功获取信号量,执行相关操作
    } else {
        // 获取信号量失败,处理超时情况
    }
    
    //中断中需使用xQueueReceiveFromISR()代替
  • 释放信号量:

    复制代码
    xSemaphoreGive(xSemaphore);
  • 删除信号量

    复制代码
    vSemaphoreDelete(xSemaphore);

二进制信号量的应用场景

二进制信号量通常用于任务间的同步和资源的互斥访问。例如:

  • 任务同步: 一个任务在执行完某个操作后,通过释放信号量通知其他任务可以继续执行。
  • 互斥锁: 确保同一时刻只有一个任务可以访问某个共享资源,避免资源冲突。

计数信号量的应用场景

计数信号量适用于管理多个相同资源的访问。例如:

  • 资源池管理: 例如多个相同类型的硬件外设,计数信号量可以用来控制这些设备的访问数量。
  • 任务同步: 多个任务等待同一个事件的发生,当事件发生时,计数信号量可以同时解除多个任务的等待状态。

小结

信号量在FreeRTOS中的使用可以有效避免任务之间的资源冲突,实现任务间的有效协作和同步。无论是二进制信号量还是计数信号量,它们都为实时操作系统提供了灵活而强大的任务同步和资源管理机制。

欢迎指出博客中的错误,如果你觉得对你有用,记得点赞三连,有问题可留言,会及时回复

相关推荐
AgilityBaby2 分钟前
UE5 2D角色PaperZD插件动画状态机学习笔记
笔记·学习·ue5
AgilityBaby3 分钟前
UE5 创建2D角色帧动画学习笔记
笔记·学习·ue5
武昌库里写JAVA1 小时前
iview Switch Tabs TabPane 使用提示Maximum call stack size exceeded堆栈溢出
java·开发语言·spring boot·学习·课程设计
一弓虽2 小时前
git 学习
git·学习
冷凌爱3 小时前
总结HTML中的文本标签
前端·笔记·html
保持学习ing4 小时前
黑马Java面试笔记之 集合篇(算法复杂度+ArrayList+LinkedList)
java·笔记·算法·面试
Moonnnn.4 小时前
【单片机期末】串行口循环缓冲区发送
笔记·单片机·嵌入式硬件·学习
viperrrrrrrrrr75 小时前
大数据学习(131)-Hive数据分析函数总结
大数据·hive·学习
fen_fen5 小时前
学习笔记(26):线性代数-张量的降维求和,简单示例
笔记·学习·算法
FakeOccupational6 小时前
【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 & 定向转发机制
笔记·分布式·p2p