一、定时器处理如下
struct timeval s_send_timeout_tv = {2, 0};
struct event *s_send_timeout_event;
static void read_terminal_cb(int fd, short what, void*arg)
{
uint i = 0;
char buf[1024] = {0};
int len = read(fd, buf, sizeof(buf));
printf("\r\n------len=%d-------\r\n", len);
if (2 == len) {
evtimer_add(s_send_timeout_event, &s_send_timeout_tv);
} else if (3 == len ){
evtimer_del(s_send_timeout_event);
} else if(4 == len) {
evtimer_add(s_send_timeout_event, &s_send_timeout_tv);
}
}
static void rs485_send_timeout_cb(int fd, short t_event, void *arg)
{
printf("\r\n--------->>>>rs485_send_timeout_cb<<<<--------------\r\n");
}
int main()
{
int i = 0;
unsigned short modbus = 0x1234;
printf("low=0x%02x high=0x%02x\r\n", modbus&0xFf, modbus>>8&0xFF);
struct event_base *base = event_init();
printf("\r\nhello world\r\n");
struct event *ev2 = event_new(base, STDIN_FILENO, EV_READ|EV_PERSIST, read_terminal_cb, NULL);
s_send_timeout_event = event_new(base, -1, 0, rs485_send_timeout_cb, (void *)0);
event_add(ev2, NULL);
event_dispatch();
}
二、实验现象
三、通过实验现象可说明,单次定时器通过evtimer_add 启动,evtimer_del停止,可循环使用。