uv-cpp是一個基於libuv的C++封裝網絡庫,基於本人實際項目需求開發並使用。接口較爲簡單易用,並對libuv一些特性作了擴展及優化。壓測結果穩定、高效。未發現內存泄漏及崩潰相關bug。node
截至目前,C++沒有標準網絡庫,常見的有ACE和boost.asio。ACE較爲龐大臃腫,封裝複雜,我的不推薦。boost.asio是boost庫的一部分,須要依賴boost的部分實現,使用asio須要在項目引入較爲龐大的boost庫。而C語言的網絡庫主要有libevent、libev及libuv。libuv是nodejs的底層,較爲成熟。因此若是在項目須要一套輕量級,且沒有太多依賴的網絡組件,最好的辦法,仍是本身封裝一套。git
1.實現了C++功能的回調
首先libuv是一個C語言庫,意味着回調函數是C語言的回調,因此直接使用libuv網絡消息回調,相關對象必須是全局的或者static對象,這是使人難以容忍的。這裏經過libuv的用戶數據功能實現了C++風格的回調,回調函數能夠類成員函數,或者lambda。同時封裝了TcpServer及TcpClient等類,簡化編程。github
2.對線程安全作了優化
libuv是一個非線程安全的庫,跨線程發送數據數不容許的。uv-cpp中實現了線程安全的跨線程write數據操做。基於libuv的async異步機制實現,同時在跨線程調用時候會檢查當前調用線程,若是在該loop線程中則直接發送,減小了沒必要要的性能損耗。實現以下:編程
void uv::EventLoop::runInThisLoop(const std::function<void()>& func) { if (nullptr == func) return; if (isRunInLoopThread()) { func(); return; } async_->runInThisLoop(func); }
同時libuv的aysnc接口存在屢次調用只執行一次的可能(特性),好比有些操做須要在回調裏面釋放數據,這樣就會內存泄漏。uv-cpp中的Async類優化這個問題,確保每次調用必定會被執行。緩存
3.實現了定時器及時間輪
對libuv定時器作了一層封裝,並實現了一個時間複雜度O(1)的時間輪,用於檢測心跳超時。安全
4.實現整包發送/接受協議機制
實現了ListBuffer和CycleBuffe兩種緩存機制,用於解決TCP的粘包及殘包。數據會從新組成完整的包數據用於讀取。性能測試顯示CycleBuffe會損失20%~30%的性能。網絡
5日誌接口
uv-cpp沒有實現日誌功能,可是保留了接口,能夠註冊/綁定到自定義日誌庫中使用。異步
詳見example文件夾:https://github.com/wlgq2/uv-c...async