Watch 77 Star 184 Fork 60

yedf / handyC++BSD-2-Clause

Create your Gitee Account
Explore and code with more than 5 million developers,Free private repositories !:)
Sign up
Clone or download 1.93 KB
Copy Edit Web IDE Raw Blame History
yedf authored 2016-08-14 19:47 . update readme

handyBuild Status


A C++11 non-blocking network library

multi platform support

  • Linux: ubuntu14 64bit g++4.8.1 tested

  • MacOSX: LLVM version 6.1.0 tested

elegant program exit

programmer can write operations for exit

can use valgrind to check memory leak

high performance

  • use epoll on Linux

  • use kqueue on MacOSX

performance report


only 10 lines can finish a complete server

sample --echo-server

#include <handy/handy.h>
using namespace handy;

int main(int argc, const char* argv[]) {
    EventBase base;
    Signal::signal(SIGINT, [&]{ base.exit(); });
    TcpServerPtr svr = TcpServer::startServer(&base, "", 99);
    exitif(svr == NULL, "start tcp server failed");
    svr->onConnRead([](const TcpConnPtr& con) {

half sync half async pattern

processing I/O asynchronously and Request synchronously can greatly simplify the coding of business processing

example can be found examples/

openssl supported

asynchronously handle the openssl connection. if you have installed openssl, then make will automatically download handy-ssl. ssl support files are in handy-ssl because of license.

###protobuf supported

examples can be found in directory protobuf


make && make install


  • handy--------handy library
  • examples----
  • ssl------------openssl support and examples
  • protobuf-----protobuf support and examples
  • test-----------handy test case

###hand book


Use of this source code is governed by a BSD-style license that can be found in the License file.


Comment ( 0 )

Sign in for post a comment