登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

Code@Pig Home

喜欢背着一袋Code傻笑的Pig .. 忧美.欢笑.记忆.忘却 .之. 角落

 
 
 

日志

 
 

[libevent] event.h(2) ---- timer  

2010-01-23 21:28:02|  分类: net_libevent |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
libevent-1.4.12-stable, libevent-2.0.4-alpha

libevent 的默认只实现了 once timer,如果期望 periodic timer,还的自己处理下。这点实现得不好,应该支持 periodic timer 的。

----------------------------------------
#include <sys/time.h>   // struct timeval
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <event.h>

void once_timer(int fd, short events, void *arg)
{
    printf("once timer = %d\n", time(NULL));
    free(arg);  // free ev
}

void init_once_timer()
{
    struct event *ev;
    struct timeval tv = { 3, 0 };

    ev = malloc(sizeof(struct event));
    evtimer_set(ev, once_timer, (void *)ev);
    evtimer_add(ev, &tv);
}

struct my_param {
    struct event ev;
    struct timeval tv;
};

void periodic_timer(int fd, short events, void *arg)
{
    struct my_param *p = (struct my_param *)arg;
    event_add(&p->ev, &p->tv);
    printf("periodic timer = %d\n", time(NULL));
}

void init_periodic_timer()
{
    struct my_param *p;
    p = malloc(sizeof(struct my_param));
    p->tv.tv_sec  = 3;
    p->tv.tv_usec = 0;
    evtimer_set(&p->ev, periodic_timer, (void *)p);
    evtimer_add(&p->ev, &p->tv);
}

int main()
{
    event_init();
    init_once_timer();
    init_periodic_timer();
    event_dispatch();
    return 0;
}
----------------------------------------
$ ./a.out
once timer = 1264252894
periodic timer = 1264252894
periodic timer = 1264252897
periodic timer = 1264252900
----------------------------------------

ps. linux 下,gcc 记得带上 -lrt 参数,用于 clock_gettime。

  评论这张
 
阅读(1587)| 评论(0)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018