Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
线程
学习记录
小白RTOS学习记录(一)
发布于 2021-08-21 00:57:26 浏览:943
订阅该版
**学习笔记(一)** RTOS提供了两种和裸机不同的调用创建的函数的方法: 一个是直接在main函数里面用线程调用; 一个是在终端处,敲写命令行进行调用,和裸机基本类似; 在想清楚这两件事情之前,首先都必须要清楚怎么创建线程 举一个流水灯的栗子 我们先理清楚这个逻辑,对于一般的裸机程序: 点灯: 初始化IO,将电平拉低就可以点亮 写一个延迟函数 电平再拉高再延迟 重复此操作 现在无非就是把裸机的程序用线程的方式封装起来,换句话来说,裸机程序的函数将作为线程的入口函数(线程函数)即xxx_thread_entry ``` /* 入口函数 */ static void led_control_thread_entry(void *parameter) { rt_pin_mode(LED0_PIN, PIN_MODE_OUTPUT); while(1){ rt_pin_write(LED0_PIN, 1); rt_kprintf("led_off\n"); rt_thread_mdelay(1000); rt_pin_write(LED0_PIN, 0); rt_kprintf("led_on\n"); rt_thread_mdelay(1000); } } ``` 当然这里的LED0_PIN巴拉巴拉是宏定义不说了 有了这个函数,书上列举了几种创建线程的方式,静态线程,动态单线程,动态多线程 这里我说说动态单线程,多线程类似: 1. 在board.c中定义RT-Thread的堆到内部SRAM(这一步studio已经帮我们做好了) 2. 定义线程控制块指针 ``` /*定义线程控制块*/ rt_thread_t led1_thread = RT_NULL; ``` 3. 定义线程函数(见上) 4. 创建线程并启动调度,这里值得注意的是rt_thread_create函数是有返回值的,如果创建成功就会返回RT_OK,否则RT_NULL,所以可以借助这个来判断是否启动调度 ``` /* 创建线程 */ int led_control(void) { /* 创建线程*/ led1_thread = rt_thread_create("led_control_thread", //给线程取的名字 led_control_thread_entry, //线程函数 RT_NULL, //线程函数的参数 LED_THREAD_STACK_SIZE, //分配给线程的栈空间的大小比如512 LED_THREAD_PRIORITY, //线程的优先级,比如25 LED_THREAD_TIMESLICE); //时间片,比如5 /* 如果获得线程控制块,启动线程,开启调度 */ if (led1_thread != RT_NULL) rt_thread_startup(led1_thread); return 0; } ``` 值得注意的是时间片,优先级,还有线程函数用的延时函数不是hal_delay,而是rt_thread_mdelay。 使用rt_thread_mdelay,线程会进入阻塞态,而在这个状态下,线程可以进行切换,优先级高的会先运行。那时间片是什么呢?时间片用于时间片轮转调度,意思是,线程一次调度能够运行的最大时间长度,就比如**同优先级**,A的时间片是5ms,B是1ms长,表示A运行完5ms后,就算没有执行完,也要把控制权交给B(假设就只有AB两个线程) 6. 这些部分都可以在创建一个led.c中完成: 这些完成过后可以在main函数中调用led_control();就可以直接开始led的闪烁 如果不创建线程,还有一种相比于裸机更高级的方式: ``` MSH_CMD_EXPORT(led_control_thread_entry, Led twinkle ); ``` 注意这里相当于是只要有led_control_thread_entry,就可以直接用,然后再命令行里面输入即可 总结一下创建线程的模板 1.对应IO的初始化,有的要再board.c中完成 2.写led.c ``` /*宏定义*/ #define LED0_PIN GET_PIN(B,3) #define LED_THREAD_PRIORITY 25 #define LED_THREAD_STACK_SIZE 512 #define LED_THREAD_TIMESLICE 5 /*定义线程控制块*/ rt_thread_t led1_thread = RT_NULL; //创建线程控制块 /*函数声明*/ static void led_control_thread_entry(void *parameter); /* 创建线程 */ int led_control(void) { /* 创建线程*/ led1_thread = rt_thread_create... /* 如果获得线程控制块,启动线程,开启调度 */ if (led1_thread != RT_NULL) rt_thread_startup(led1_thread); return 0; } /* 入口函数 */ static void led_control_thread_entry(void *parameter) { xxx } ``` 3.main.c中调用led_control() 好嘞,先这样
0
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
骁骑校尉
这家伙很懒,什么也没写!
文章
3
回答
3
被采纳
0
关注TA
发私信
相关文章
1
请问执行rt_thread_delete的操作后,线程还在运行是什么情况?
2
rtthread中,线程中的ADC采样率需求比时钟嘀嗒需求高怎么办?
3
有没有检测系统中有没有某个名字的线程的接口函数?
4
使用finsh 进行ota成功,线程里开ota失败
5
调度锁会引起线程内存不足
6
线程处于close状态消耗资源吗
7
paho_mqtt线程相关疑问
8
thread中不能使用rt_timer_start() 来开启定时器
9
线程递归是什么形成的?
10
程序运行一会儿报错,拜托拜托
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
rt_mq_消息队列_msg_queue
SFUD
keil_MDK
msh
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
812
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
2
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部