Engineering a Reactor -- how to write a non-blocking network library from scratch. Step 0: a do-nothing event loop EventLoop, assertInLoopThread() test1: poll for 10 seconds, creates two threads, each one has an EventLoop test2: abort() as it accesses event loop created in a different thread Step 1: prototype of reactor Channel, Poller, updateChannel(). test1: poll for ever, creates two threads, each one has an EventLoop test2: same as before test3: poll a timerfd, which expires in 5 seconds Step 2: TimerQueue TimerQueue, Timer, TimerId, EventLoop::runAfter, EventLoop::runEvery not thread safe test4: timer queue unittest Step 3: wakeup(), runInLoop() test5: runInLoop(), runAfter() in loop thread test6: runInLoop(), runAfter() in a different thread Step 4: Acceptor test7: listen on port 9981, accept, send, and close Step 5: TcpServer test8: use of TcpServer, create TcpConnection Step 6: TcpConnection passive close Step 7: TcpConnection read with Buffer, add receiveTime to read callback test3: show receiveTime test8: show receiveTime Step 8: TcpConnection write, write complete callback, SIGPIPE Step 9: multithreaded TcpServer Step 10: Connector Step 11: TcpClient Step 12: epoll