RT-Thread线程的挂起和恢复

#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "led.h"
#include "rtthread.h"

/*
* 线程删除(rt_thread_delete)函数仅适合于动态线程,为了在一个线程
* 中访问另一个线程的控制块,所以把线程块指针声明成全局类型以供全
* 局访问
*/
static rt_thread_t tid1 = RT_NULL, tid2 = RT_NULL;

/* 线程1的入口函数 */
static void thread1_entry(void* parameter)
{
	rt_uint32_t count = 0;
	while (1)
	{
		/* 线程1采用低优先级运行,一直打印计数值 */
		rt_kprintf("thread1 count: %d\n", count ++);
		rt_thread_delay(20);
	}
}

/* 线程2的入口函数 */
static void thread2_entry(void* parameter)
{
	rt_err_t rt_err;

	/* 线程2拥有较高的优先级,以抢占线程1而获得执行 */
	/* 线程2启动后先睡眠10个OS Tick */
	rt_thread_delay(1000);
	/*
	* 线程2唤醒后直接删除线程1,删除线程1后,线程1自动脱离就绪线程
	* 队列
	*/
	rt_err=rt_thread_delete(tid1);
	if(rt_err!=RT_EOK)
	{
		rt_kprintf("线程 nthread1 删除失败\n");
	}
	else
	{
		rt_kprintf("线程 nthread1 删除成功\n");
	}
	tid1 = RT_NULL;
	/*
	* 线程2继续休眠100个OS Tick然后退出,线程2休眠后应切换到idle线程
	* idle线程将执行真正的线程1控制块和线程栈的删除
	*/
	rt_thread_delay(100);
	/*
	* 线程2运行结束后也将自动被删除(线程控制块和线程栈依然在idle线
	* 程中释放)
	*/
	tid2 = RT_NULL;
}

int main()
{
	//创建线程1 
    tid1 = rt_thread_create("t1", //线程1的名称是t1 
							thread1_entry, RT_NULL, //入口是thread1_entry,参数是RT_NULL 
							512, //线程堆栈大小
							10, //线程优先级
							20);//时间片tick

	if (tid1 != RT_NULL) //如果获得线程控制块,启动这个线程
			rt_thread_startup(tid1);
	else
			rt_kprintf("创建线程1失败\n");
		
	//创建线程2
	tid2 = rt_thread_create("t2", //线程1的名称是t2 
							thread2_entry, RT_NULL, //入口是thread2_entry,参数是RT_NULL 
							512,  //线程堆栈大小
							9, //线程优先级
							20);//时间片tick
	
	if (tid2 != RT_NULL) // 如果获得线程控制块,启动这个线程 
			rt_thread_startup(tid2);
	else
			rt_kprintf("c创建线程1失败\n");
	
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值