RTX5 | 线程标志组01 - 线程同步
文章目錄
- 一、前言
- 二、實驗目的
- 三、API
- 3.1、osThreadFlagsSet
- 3.2、osThreadFlagsWait
- 四、代碼
- 4.1、main.h
- 4.2、main.c
- 五、Event Recorder調試
- 5.1、長按按鍵KEY1與長按按鍵KEY2
- 5.2、線程同步的效果
- 5.3、將線程同步的地方放大
一、前言
線程標志組(Thread Flags)與事件標志組(Event Flags)的作用一樣,都是用于線程(ISR)與線程之間通訊(同步)。線程標志與事件標志的區別是事件標志跟線程沒有直接關系,所以事件標志需要創建之后才能使用的。線程標志屬于線程的一部分,創建線程的同時,線程標志就已經被創建了。
以下是官方的描述:
線程標志組API函數匯總:
STM32工程:
鏈接:https://pan.baidu.com/s/10uQNtRO9nUtQNh0NWVhpeA
提取碼:60p1
二、實驗目的
長按按鍵KEY1發送線程標志(0x02U)給Test_Flags_App線程,實現LED_App線程同步Test_Flags_App線程。
長按按鍵KEY2發送線程標志(0x01U)給Test_Flags_App線程,實現LED_App線程同步Test_Flags_App線程。
三、API
3.1、osThreadFlagsSet
/* 使用舉例 */ osThreadFlagsSet(threadID_Test_Flags_Thread,0x02U); /* 置位Test_Flags線程的flag1 */ osThreadFlagsSet(threadID_Test_Flags_Thread,0x01U); /* 置位Test_Flags線程的flag0 */ osThreadFlagsSet(threadID_Test_Flags_Thread,0x08U); /* 置位Test_Flags線程的flag3 */3.2、osThreadFlagsWait
void thread_A(void *argument) {uint32_t flags;while(1){/* 一直等待,直到線程標志的flag0或flag1被置位 */flags = osThreadFlagsWait(0x00000003U, /* flag0 ,flag1 */osFlagsWaitAny, /* 邏輯或,清除標志 */osWaitForever /* 一直等待 */); /* 一直等待,直到線程標志的flag0,flag1,flag2,flag3都被置位 */flags = osThreadFlagsWait(0x0000000FU, /* flag0,flag1,flag2,flag3 */osFlagsWaitAll, /* 邏輯與,清除標志 */osWaitForever /* 一直等待 */); /* 一直等待,直到線程標志的flag0,flag1,flag2,flag3都被置位 */flags = osThreadFlagsWait(0x0000000FU, /* flag0,flag1,flag2,flag3 */osFlagsWaitAll | osFlagsNoClear, /* 邏輯與,不清除標志 */osWaitForever /* 一直等待 */); } }四、代碼
4.1、main.h
4.2、main.c
五、Event Recorder調試
5.1、長按按鍵KEY1與長按按鍵KEY2
5.2、線程同步的效果
LED線程每隔500ms執行一次,當一直按著按鍵時,Test_Flags線程將跟LED線程同步,也是每500ms運行一次。
5.3、將線程同步的地方放大
LED線程的優先級是osPriorityLow,Test_Flags線程的優先級是osPriorityBelowNormal,Test_Flag線程的優先級要高許多。當LED線程發送線程標志給Test_Flags線程時會觸發調度器,調度器將運行權交給Test_Flags線程,LED線程暫時進入阻塞態,等待Test_Flags運行完畢。
再做一次測試,將LED線程與Test_Flags線程的優先級互換,即LED線程的優先級是osPriorityBelowNormal,Test_Flags線程的優先級是osPriorityLow。
總結
以上是生活随笔為你收集整理的RTX5 | 线程标志组01 - 线程同步的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dos导入mysql数据库表_用DOS命
- 下一篇: STM32H743+CubeMX-使用A