• FreeRTOS学习day1


    顾名思义 免费的实时操作系统

    用法基本和Linux下的多线程编程类似

    探索者开发版实验

    动态创建4个任务start_task task1 task2 task3  优先级依次为1 2 3 4 (注意优先级不能为0,0是空闲任务)

    我的理解:主线程start_task 主线程   task1 task2 task3为子线程

    1. #include "sys.h"
    2. #include "delay.h"
    3. #include "usart.h"
    4. #include "led.h"
    5. #include "FreeRTOS.h"
    6. #include "task.h"
    7. #define START_TASK_PRIO 1 //任务优先级
    8. #define START_STK_SIZE 120 //任务堆栈
    9. TaskHandle_t Start_Handler;
    10. void start_task(void *pvParameters);
    11. #define Task1_TASK_PRIO 2 //任务优先级
    12. #define Task1_STK_SIZE 120 //任务堆栈
    13. TaskHandle_t Task1_Handler;
    14. void task1_task(void *pvParameters);
    15. #define Task2_TASK_PRIO 3 //任务优先级
    16. #define Task2_STK_SIZE 120 //任务堆栈
    17. TaskHandle_t Task2_Handler;
    18. void task2_task(void *pvParameters);
    19. #define Task3_TASK_PRIO 4 //任务优先级
    20. #define Task3_STK_SIZE 120 //任务堆栈
    21. TaskHandle_t Task3_Handler;
    22. void task3_task(void *pvParameters);
    23. //*******************下面注释掉的代码是通过 位带 操作实现IO口控制**************************************
    24. int main(void)
    25. {
    26. uart_init(115200);
    27. delay_init(168); //初始化延时函数
    28. LED_Init(); //初始化LED端口
    29. while(1)
    30. {
    31. xTaskCreate((TaskFunction_t) start_task,
    32. (char *) "start_task",
    33. (uint16_t) START_STK_SIZE,
    34. (void *) NULL,
    35. (UBaseType_t) START_TASK_PRIO,
    36. (TaskHandle_t *) &Start_Handler ); /*lint !e971 Unqualified char types are allowed for strings and single characters only. */
    37. vTaskStartScheduler();// 开启任务调度器 注意一定要开启
    38. }
    39. }
    40. //创建开始任务
    41. void start_task(void *pvParameters)
    42. {
    43. //创建task1
    44. xTaskCreate((TaskFunction_t) task1_task,
    45. (char *) "task1_task",
    46. (uint16_t) Task1_STK_SIZE,
    47. (void *) NULL,
    48. (UBaseType_t) Task1_TASK_PRIO,
    49. (TaskHandle_t *) &Task1_Handler ); /*lint !e971 Unqualified char types are allowed for strings and single characters only. */
    50. //创建task2
    51. xTaskCreate((TaskFunction_t) task2_task,
    52. (char *) "task2_task",
    53. (uint16_t) Task2_STK_SIZE,
    54. (void *) NULL,
    55. (UBaseType_t) Task2_TASK_PRIO,
    56. (TaskHandle_t *) &Task2_Handler ); /*lint !e971 Unqualified char types are allowed for strings and single characters only. */
    57. //创建task3
    58. xTaskCreate((TaskFunction_t) task3_task,
    59. (char *) "task3_task",
    60. (uint16_t) Task3_STK_SIZE,
    61. (void *) NULL,
    62. (UBaseType_t) Task3_TASK_PRIO,
    63. (TaskHandle_t *) &Task3_Handler ); /*lint !e971 Unqualified char types are allowed for strings and single characters only. */
    64. vTaskDelete(Start_Handler);
    65. }
    66. void task1_task(void *pvParameters)
    67. {
    68. while(1)
    69. {
    70. printf("task 1 is ok\r\n");
    71. vTaskDelay(500);
    72. }
    73. }
    74. void task2_task(void *pvParameters)
    75. {
    76. while(1)
    77. {
    78. printf("task 2 is ok\r\n");
    79. vTaskDelay(800);
    80. }
    81. }
    82. void task3_task(void *pvParameters)
    83. {
    84. while(1)
    85. {
    86. printf("task 3 is ok\r\n");
    87. vTaskDelay(1000);
    88. }
    89. }

    n: 运行态的任务调用vTaskDelay(),将把自己从就绪列表搬移到主动延时列表,并让就绪表的其他任务获取CPU资源。

    h: 延时态的任务在延时结束时,若优先级比当前任务优先级高,就加入就绪队列,并立即获得CPU资源,进入运行。

    g: 延时态的任务在延时结束时,若优先级比当前任务优先级低,就加入就绪队列,但是由于优先级不够,只能等待获取CPU资源。

    如果不加延时 会一直执行高优先级的任务

  • 相关阅读:
    跑马灯带你深入浅出TextView的源码世界
    java:代理模式
    什么是生成式人工智能?人工智能创造
    《Kubernetes部署篇:Ubuntu20.04基于外部etcd+部署kubernetes1.25.14集群(多主多从)》
    壳聚糖-凝集素|Chitosan-Lectins|凝集素-PEG-壳聚糖|壳聚糖-聚乙二醇-凝集素
    Python 系统学习总结(基础语法+函数+数据容器+文件+异常+包+面向对象)
    Windows11右键菜单修改为Win10模式的方法
    【23种设计模式】建造者模式【⭐⭐⭐】
    前端技术-并发请求
    java设计模式1,单一职责原则
  • 原文地址:https://blog.csdn.net/weixin_64975583/article/details/133979050