一个定时器显示函数执行的时间
另外一个定时器显示计数值
工程参考例程在:
RT-Thread物联网操作系统介绍
/* 定义线软件定时器制块 */
static rt_timer_t S_Timer1 = RT_NULL;
static rt_timer_t S_Timer2 = RT_NULL;
static uint32_t xTimers1 = 0;
static uint32_t xTimers2 = 0;
//定时器1回调函数
tatic void S_Timer1_callback(void* parameter)
{
uint32_t Tick_count1;
xTimers1++; /* 每回调一次加一 */
Tick_count1 = (uint32_t)rt_tick_get(); /* 获取滴答定时器的计数值 */
rt_kprintf("S_Timer1_callback函数执行 %d 次n", xTimers1);
rt_kprintf("滴答定时器数值=%dn", Tick_count1);
}
//定时器2回调函数
static void S_Timer2_callback(void* parameter)
{
uint32_t Tick_count2;
xTimers2++; /* 每回调一次加一 */
Tick_count2 = (uint32_t)rt_tick_get(); /* 获取滴答定时器的计数值 */
rt_kprintf("S_Timer2_callback函数执行 %d 次n", xTimers2);
rt_kprintf("滴答定时器数值=%dn", Tick_count2);
}
```c
/* 创建一个S_Timer1_callback软件定时器 */
S_Timer1 = rt_timer_create("S_Timer1_callback", /* 软件定时器的名称 */
S_Timer1_callback, /* 软件定时器的回调函数 */
0, /* 定时器超时函数的入口参数 */
5000, /* 软件定时器的超时时间(周期回调时间) */
RT_TIMER_FLAG_ONE_SHOT | RT_TIMER_FLAG_SOFT_TIMER);
/* 软件定时器模式 一次模式 */
/* 启动定时器 */
if (S_Timer1 != RT_NULL)
rt_timer_start(S_Timer1);
/* 创建一个S_Timer2_callback软件定时器 */
S_Timer2 = rt_timer_create("S_Timer2_callback", /* 软件定时器的名称 */
S_Timer2_callback, /* 软件定时器的回调函数 */
0, /* 定时器超时函数的入口参数 */
1000, /* 软件定时器的超时时间(周期回调时间) */
RT_TIMER_FLAG_PERIODIC | RT_TIMER_FLAG_SOFT_TIMER);
/* 软件定时器模式 周期模式 */
/* 启动定时器 */
if (S_Timer2 != RT_NULL)
rt_timer_start(S_Timer2);
最后
以上就是笑点低彩虹最近收集整理的关于RT-Thread物联网操作系统介绍:14、软件定时器的全部内容,更多相关RT-Thread物联网操作系统介绍内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复