資源描述:
《libevent參考手冊(中文版).pdf》由會員上傳分享,免費在線閱讀,更多相關內容在教育資源-天天文庫。
1、原創(chuàng):http://blog.sina.com.cn/yaozj整理:http://yaocoder.blog.51cto.com/前言翻譯自:http://www.wangafu.net/~nickm/libevent-book/Ref0_meta.html1.從一萬英尺外看LibeventLibevent是用于編寫高速可移植非阻塞IO應用的庫,其設計目標是:?可移植性:使用libevent編寫的程序應該可以在libevent支持的所有平臺上工作。即使沒有好的方式進行非阻塞IO,libevent也應該支持一般的方式,讓程序可以在受限的環(huán)境中運行。?速度:libevent嘗試使用每個
2、平臺上最高速的非阻塞IO實現,并且不引入太多的額外開銷。?可擴展性:libevent被設計為程序即使需要上萬個活動套接字的時候也可以良好工作。?方便:無論何時,最自然的使用libevent編寫程序的方式應該是穩(wěn)定的、可移植的。libevent由下列組件構成:?evutil:用于抽象不同平臺網絡實現差異的通用功能。?event和event_base:libevent的核心,為各種平臺特定的、基于事件的非阻塞IO后端提供抽象API,讓程序可以知道套接字何時已經準備好,可以讀或者寫,并且處理基本的超時功能,檢測OS信號。?bufferevent:為libevent基于事件的核心提供使用更方
3、便的封裝。除了通知程序套接字已經準備好讀寫之外,還讓程序可以請求緩沖的讀寫操作,可以知道何時IO已經真正發(fā)生。(bufferevent接口有多個后端,可以采用系統(tǒng)能夠提供的更快的非阻塞IO方式,如Windows中的IOCP。)?evbuffer:在bufferevent層之下實現了緩沖功能,并且提供了方便有效的訪問函數。?evhttp:一個簡單的HTTP客戶端/服務器實現。?evdns:一個簡單的DNS客戶端/服務器實現。?evrpc:一個簡單的RPC實現。2.庫創(chuàng)建libevent時,默認安裝下列庫:?ibevent_core:所有核心的事件和緩沖功能,包含了所有的event_ba
4、se、evbuffer、bufferevent和工具函數。?ibevent_extra:定義了程序可能需要,也可能不需要的協(xié)議特定功能,包括HTTP、DNS和RPC。?libevent:這個庫因為歷史原因而存在,它包含libevent_core和libevent_extra的內容。不應該使用這個庫,未來版本的libevent可能去掉這個庫。某些平臺上可能安裝下列庫:?libevent_pthreads:添加基于pthread可移植線程庫的線程和鎖定實現。它獨立于libevent_core,這樣程序使用libevent時就不需要鏈接到pthread,除非是以多線程方式使用libeven
5、t。?libevent_openssl:這個庫為使用bufferevent和OpenSSL進行加密的通信提供支持。它獨立于libevent_core,這樣程序使用libevent時就不需要鏈接到OpenSSL,除非是進行加密通信。3.頭文件libevent公用頭文件都安裝在event2目錄中,分為三類:?API頭文件:定義libevent公用接口。這類頭文件沒有特定后綴。?兼容頭文件:為已廢棄的函數提供兼容的頭部包含定義。不應該使用這類頭文件,除非是在移植使用較老版本libevent的程序時。?結構頭文件:這類頭文件以相對不穩(wěn)定的布局定義各種結構體。這些結構體中的一些是為了提供快速訪
6、問而暴露;一些是因為歷史原因而暴露。直接依賴這類頭文件中的任何結構體都會破壞程序對其他版本libevent的二進制兼容性,有時候是以非常難以調試的方式出現。這類頭文件具有后綴“_struct.h”。(還存在不在event2目錄中的較老版本libevent的頭文件,請參考下節(jié):如果需要使用老版本libevent)4.如果需要使用老版本libeventlibevent2.0以更合理的、不易出錯的方式修正了API。如果可能,編寫新程序時應該使用libevent2.0。但是有時候可能需要使用較老的API,例如在升級已存的應用時,或者支持因為某些原因不能安裝2.0或者更新版本libevent的
7、環(huán)境時。較老版本的libevent頭文件較少,也不安裝在event2目錄中。在2.0以及以后版本的libevent中,老的頭文件仍然會作為新頭文件的封裝而存在。其他關于使用較老版本的提示:?1.4版之前只有一個庫libevent,它包含現在分散到libevent_core和libevent_extra中的所有功能。?2.0版之前不支持鎖定:只有確定不同時在多個線程中使用同一個結構體時,libevent才是線程安全的。下面的節(jié)還將討論特定代碼區(qū)域可能遇到的已