• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            XGuru's Blog

            技術,是一種態(tài)度。關注:高性能后端技術/服務器架構(gòu)/C++/C/LAMP

               :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              20 Posts :: 0 Stories :: 93 Comments :: 0 Trackbacks

            公告





            twitter / xoXGuru

            feedsky
            抓虾
            google reader
            鲜果
            QQ邮箱
            九点

            常用鏈接

            留言簿(12)

            搜索

            •  

            最新評論

            閱讀排行榜

            Libevent簡介

            The libevent API provides a mechanism to execute a callback function when a specific event occurs on a file descriptor or after a timeout has been reached. Furthermore, libevent also support callbacks due to signals or regular timeouts. 

             

            Libevent的API提供了這樣的一套機制:
            當指定文件描述符中一個特定的事件發(fā)生,或者超時時間到達后執(zhí)行指定的回調(diào)函數(shù)。
            此外,libevent回調(diào)功能也支持由信號或者常規(guī)的超時觸發(fā)。
            注意其許可協(xié)議為BSD-style的協(xié)議,可以在商業(yè)級產(chǎn)品中采用而不必開源。

             

            1.編譯安裝


             

            ubuntu下可以使用apt的方法直接安裝:

             

             ~$  sudo apt-get install libevent

            或者使用

            ~$  wget http://monkey.org/~provos/libevent-1.4.13-stable.tar.gz
            ~$  tar –xzvf  libevent-1.4.13-stable.tar.gz
            ~$  cd libevent-1.4.13-stable
            ~$  ./configure
            ~$  make
            ~$  sudo make install

            2.庫的使用
             

            可以從這幾個簡單的例子中了解到libevent的基本使用方法。編譯時需加上 "-levent"參數(shù)。

             

            2.1.I/O事件(對應EV_READ、EV_WRITE)

            下面提供了一個有所省略簡單使用libevent返回系統(tǒng)時間的服務端程序片段。

             1void get_time(int fd,short event,struct event *arg)  /*獲取系統(tǒng)時間并將其往回write*/
             2{
             3……
             4    localtime_r(&now,&t);
             5    asctime_r(&t,buf);
             6    write( fd,buf,strlen(buf) );
             7……
             8}

             9void con_accept(int fd,short event,void *arg) /*提供給事件的回調(diào)函數(shù),接收一個連接*/
            10{
            11    struct sockaddr_in s_in;
            12    socklen_t len = sizeof(s_in);
            13    int ns = accept(fd,(struct sockaddr *&s_in,&len);
            14    struct event *ev = malloc(sizeof(struct event));
            15    event_set(ev,ns,EV_WRITE,(void *)get_time,ev);
            16    event_add(ev,NULL);
            17}

            18                
            19int main()
            20{
            21    int sockfd = socket(PF_INET,SOCK_STREAM,0);
            22    struct sockaddr_in s_in;
            23……
            24    bind(sockfd,(struct sockaddr*&s_in,sizeof(s_in));
            25    listen(sockfd,5);
            26    event_init(); //libevent初始化
            27
            28    struct event ev;
            29    event_set(&ev,sockfd,EV_READ|EV_PERSIST,con_accept,&ev);
            30//設置事件屬性為可讀、持續(xù),回調(diào)函數(shù)為con_accept()
            31    event_add(&ev,NULL);//添加事件,未設置超時時間
            32    event_dispatch();//進入libevent主循環(huán)
            33    return 0;
            34}

            35

            2.2. 信號處理事件(對應EV_SIGNAL)

             1 static void signal_cb(int fd, short eventvoid *arg)
             2{
             3    struct event *signal = arg;
             4    printf("%s: got signal %d\n", __func__, EVENT_SIGNAL(signal));
             5    if (called >= 2)
             6        event_del(signal); //如果調(diào)用了兩次以上,就刪除這個信號
             7    called++;
             8}

             9
            10int main (int argc, char **argv)
            11{
            12    struct event signal_int;
            13    event_init();//libevent初始化
            14    event_set(&signal_int, SIGINT, EV_SIGNAL|EV_PERSIST, signal_cb, &signal_int); 
            15//設置事件屬性為信號觸發(fā)、持續(xù),回調(diào)函數(shù)為con_accept()
            16    event_add(&signal_int, NULL); //添加事件
            17    event_dispatch();//進入libevent主循環(huán)
            18    return 0;
            19}

            20

            2.3.常規(guī)超時處理(對應EV_TIMEOUT)
             1static void timeout_cb(int fd, short eventvoid *arg)
             2{
             3    struct timeval tv;
             4    struct event *timeout = arg;
             5    int newtime = time(NULL);
             6    printf("%s: called at %d: %d\n", __func__, newtime,
             7        newtime - lasttime);
             8    lasttime = newtime;
             9    evutil_timerclear(&tv);
            10    tv.tv_sec = 2;
            11    event_add(timeout, &tv);
            12}

            13
            14int main (int argc, char **argv)
            15{
            16    struct event timeout;
            17    struct timeval tv;
            18    event_init();//libevent初始化
            19    evtimer_set(&timeout, timeout_cb, &timeout);
            20//實際上該函數(shù)對應的是event_set(timeout, -1, 0, timeout_cb,&timeout)
            21evutil_timerclear(&tv); //如果有時間清理函數(shù)則直接對應timerclear(),如果沒有則將tv_sec和tv_usec設置為0
            22
            23    tv.tv_sec = 2;
            24    event_add(&timeout, &tv);
            25    lasttime = time(NULL);
            26    event_dispatch();
            27    return 0;
            28}

            29

            posted on 2010-06-24 00:13 XGuru 閱讀(6056) 評論(0)  編輯 收藏 引用
            精品久久久久久久久午夜福利| 热久久这里只有精品| 亚洲а∨天堂久久精品9966| 久久男人中文字幕资源站| 亚州日韩精品专区久久久| 久久久一本精品99久久精品88| 亚洲va久久久噜噜噜久久| 久久青草国产精品一区| 欧美粉嫩小泬久久久久久久 | 久久本道久久综合伊人| 久久久久亚洲AV片无码下载蜜桃| .精品久久久麻豆国产精品| 日韩影院久久| 国内精品久久久久久麻豆| 思思久久精品在热线热| 中文字幕成人精品久久不卡| 中文字幕人妻色偷偷久久| 亚洲乱码日产精品a级毛片久久 | 精品熟女少妇av免费久久| 中文字幕无码久久人妻| 久久久WWW成人免费毛片| 久久精品国产91久久麻豆自制| 国产69精品久久久久久人妻精品| 久久亚洲视频| 久久久久亚洲精品无码网址| 国产激情久久久久影院| 麻豆精品久久精品色综合| 91精品国产高清91久久久久久| 亚洲国产精品无码久久久蜜芽 | 久久频这里精品99香蕉久| 久久久精品日本一区二区三区| 国产精品成人99久久久久| 国产一区二区三精品久久久无广告| 狠狠久久亚洲欧美专区| 亚洲国产精久久久久久久| 香蕉久久一区二区不卡无毒影院| 久久婷婷综合中文字幕| 91久久精品国产91性色也| 久久国产影院| 一本久久a久久精品vr综合| 久久精品国产亚洲AV无码娇色|