1、获取版本
#include <event.h>
#include <stdio.h>
int main()
{
const char *version = event_get_version();
printf("%s\n",version);
return 0;
}
shenhuayu@shenhuayu-VirtualBox ~/libevent $ gcc getversion.c -o getVersion -leventshenhuayu@shenhuayu-VirtualBox ~/libevent $ ./getVersion
2.0.21-stable
2、timer程序
#include<stdio.h>
#include<event.h>
#include <event2/bufferevent.h>
#include <event2/buffer.h>
#include <event2/listener.h>
#include <event2/util.h>
#include <event2/event.h>
int lasttime;
//这里是静态函数
static void timeout_cb(int fd,short event,void *arg)
{//注意这里传递的参数对于定时事件来说fd=-1,event=0
struct timeval tv;
struct event *timeout=arg;
int newtime=time(NULL);
printf("%s:called at %d:%d\n","timeout_cb",newtime,newtime-lasttime);
lasttime=newtime;
//下面三行重新注册tv时间
evutil_timerclear(&tv);
tv.tv_sec=2;
event_add(timeout,&tv);
}
int main(int argc,char *argv[])
{
struct event timeout;
struct timeval tv;
event_init();
evtimer_set(&timeout,timeout_cb,&timeout);//设置定时器,这里evtimer_set是event_new的简写
evutil_timerclear(&tv);
tv.tv_sec=2;
event_add(&timeout,&tv);
lasttime=time(NULL);
event_dispatch();//事件主循环
return 0;
}
shenhuayu@shenhuayu-VirtualBox ~/libevent $ gcc test.c -g -o mytest -leventshenhuayu@shenhuayu-VirtualBox ~/libevent $ ./mytest
timeout_cb:called at 1403249992:2
timeout_cb:called at 1403249994:2
timeout_cb:called at 1403249996:2
timeout_cb:called at 1403249998:2
timeout_cb:called at 1403250000:2
timeout_cb:called at 1403250002:2
timeout_cb:called at 1403250004:2
timeout_cb:called at 1403250006:2
timeout_cb:called at 1403250008:2
timeout_cb:called at 1403250010:2
timeout_cb:called at 1403250012:2
timeout_cb:called at 1403250014:2
timeout_cb:called at 1403250016:2
^C