https://github.com/wlgq2/uv-cpp
libuv wrapper in C++11 /libuv C++11网络库
https://github.com/wlgq2/uv-cpp
libuv tcp
Last synced: 6 days ago
JSON representation
libuv wrapper in C++11 /libuv C++11网络库
- Host: GitHub
- URL: https://github.com/wlgq2/uv-cpp
- Owner: wlgq2
- License: mit
- Created: 2017-07-04T05:17:12.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2025-11-13T06:46:27.000Z (3 months ago)
- Last Synced: 2025-11-13T08:34:05.748Z (3 months ago)
- Topics: libuv, tcp
- Language: C++
- Homepage:
- Size: 10.3 MB
- Stars: 828
- Watchers: 44
- Forks: 215
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- fucking-awesome-cpp - uv-cpp - a simple interface, high-performance network library based on C++11. [MIT] (Asynchronous Event Loop)
- awesome-cpp - uv-cpp - a simple interface, high-performance network library based on C++11. [MIT] (Asynchronous Event Loop)
README
# uv-cpp
[](https://github.com/wlgq2/uv-cpp)
[](LICENSE)
[](http://www.repostatus.org/#active)

Language Translations:
* [English](README.md)
* [简体中文](README_cn.md)
** **
uv-cpp is a simple interface, high-performance network library based on C++11.
## Dependencies
* [libuv][1]
## Features
* C++11 functional/bind style callback instead of C-style function pointer.
* `TCP` and `UDP` wrapper.
* `DNS`and`Http`:DNS query and http support,Http routing based on radix tree.
* `Timer`and`TimerWheel`:Heartbeat timeout judgment with time complexity of O(1).
* `Async`:libuv async wrapper,but optimized the [problem][2] of calling multiple times but callback will only be called once.
* `Packet`and`PacketBuffer`:Send and receive packet of Tcp data stream. Support custom data packet structure (such as [uvnsq][3])
* Log interface.
** **
## Build Instructions
* VS2017 (windows)
* Codeblocks (linux)
* CMake (linux)
** **
## Benchmark
### ping-pong VS boost.asio-1.67
environment:Intel Core i5 8265U + debian8 + gcc8.3.0 + libuv1.30.0 + '-O2'
size peer pack | 1K bytes|2K bytes|4K bytes|8K bytes|
:---------:|:--------:|:--------:|:--------:|:--------:|
uv-cpp | 16138 kbyte|32071 kbyte|59264 kbyte|123813 kbyte|
boost.asio | 16119 kbyte|31566 kbyte|58322 kbyte|126210 kbyte|

environment:i5-8265U + 4G memory + 4k bytes ping-pong
concurrency| 10|100|1000|5000|
:---------:|:--------:|:--------:|:--------:|:--------:|
uv-cpp | 654282 kbyte|591869 kbyte|401500 kbyte|412855 kbyte|
boost.asio | 633818 kbyte|585716 kbyte|371386 kbyte|382402 kbyte|

### Apache bench VS nginx-1.14.2
environment:Intel Core i5 8265U + debian8 + gcc8.3.0 + libuv1.30.0 + '-O2'
1000 concurrency && 100000 request.


## Quick start
A simple echo server
```C++
#include
#include
int main(int argc, char** args)
{
uv::EventLoop* loop = uv::EventLoop::DefaultLoop();
uv::TcpServer server(loop);
server.setMessageCallback([](uv::TcpConnectionPtr ptr,const char* data, ssize_t size)
{
ptr->write(data, size, nullptr);
});
//server.setTimeout(60); //heartbeat timeout.
uv::SocketAddr addr("0.0.0.0", 10005, uv::SocketAddr::Ipv4);
server.bindAndListen(addr);
loop->run();
}
```
A simple http service router which based on radix tree.
```C++
int main(int argc, char** args)
{
uv::EventLoop loop;
uv::http::HttpServer::SetBufferMode(uv::GlobalConfig::BufferMode::CycleBuffer);
uv::http::HttpServer server(&loop);
//example: 127.0.0.1:10010/test
server.Get("/test",std::bind(&func1,std::placeholders::_1,std::placeholders::_2));
//example: 127.0.0.1:10010/some123abc
server.Get("/some*",std::bind(&func2, std::placeholders::_1, std::placeholders::_2));
//example: 127.0.0.1:10010/value:1234
server.Get("/value:",std::bind(&func3, std::placeholders::_1, std::placeholders::_2));
//example: 127.0.0.1:10010/sum?param1=100¶m2=23
server.Get("/sum",std::bind(&func4, std::placeholders::_1, std::placeholders::_2));
uv::SocketAddr addr("127.0.0.1", 10010);
server.bindAndListen(addr);
loop.run();
}
```
More examples [here][4].
API's document [here][5].
[1]: https://github.com/libuv/libuv
[2]: http://docs.libuv.org/en/v1.x/async.html
[3]: https://github.com/wlgq2/uvnsq
[4]: https://github.com/wlgq2/uv-cpp/tree/master/examples
[5]: https://github.com/wlgq2/uv-cpp/tree/master/doc