定时器回调函数不要用 阻塞式的 函数,若只是周期性发送和接收,可以 建立一个线程 或者 通过系统的tick读取两次差值做到,供参考如下:
//重置tick
void tick_reset(u32_t *tick)
{
*tick = rt_tick_get();
}
//获取当前系统tick
u32_t tick_get(void)
{
return rt_tick_get();
}
//获取时间差 (差值为ms级别 由RT_TICK_PER_SECOND决定的)
u32_t get_delta_time_ms(u32_t now_tick, u32_t last_tick)
{
if (now_tick >= last_tick)
{
return (now_tick - last_tick);
}
else
{
return (UINT32_MAX - last_tick + now_tick + 1);
}
}
static void send_to_acdc(void)
{
u32_t now_tick = 0;
/////////////////////////////////////////////
now_tick = tick_get();
if (get_delta_time_ms(now_tick, g_time_tick.acdc_can_connect_status_tick) >= 1000)
//1s
{
tick_reset(&(g_time_tick.acdc_can_connect_status_tick));
acdc_get_work_status(ACDC_MODULE_ADDRESS_01);
}
/////////////////////////////////////////////
}
定时器回调函数不要用 阻塞式的 函数,若只是周期性发送和接收,可以 建立一个线程 或者 通过系统的tick读取两次差值做到,供参考如下:
//重置tick
void tick_reset(u32_t *tick)
{
*tick = rt_tick_get();
}
//获取当前系统tick
u32_t tick_get(void)
{
return rt_tick_get();
}
//获取时间差 (差值为ms级别 由RT_TICK_PER_SECOND决定的)
u32_t get_delta_time_ms(u32_t now_tick, u32_t last_tick)
{
if (now_tick >= last_tick)
{
return (now_tick - last_tick);
}
else
{
return (UINT32_MAX - last_tick + now_tick + 1);
}
}
static void send_to_acdc(void)
{
u32_t now_tick = 0;
/////////////////////////////////////////////
now_tick = tick_get();
if (get_delta_time_ms(now_tick, g_time_tick.acdc_can_connect_status_tick) >= 1000)
//1s
{
tick_reset(&(g_time_tick.acdc_can_connect_status_tick));
acdc_get_work_status(ACDC_MODULE_ADDRESS_01);
}
/////////////////////////////////////////////
}
举报