1Engineering a Reactor 2 -- how to write a non-blocking network library from scratch. 3 4Step 0: a do-nothing event loop 5 EventLoop, assertInLoopThread() 6 test1: poll for 10 seconds, creates two threads, each one has an EventLoop 7 test2: abort() as it accesses event loop created in a different thread 8 9Step 1: prototype of reactor 10 Channel, Poller, updateChannel(). 11 test1: poll for ever, creates two threads, each one has an EventLoop 12 test2: same as before 13 test3: poll a timerfd, which expires in 5 seconds 14 15Step 2: TimerQueue 16 TimerQueue, Timer, TimerId, EventLoop::runAfter, EventLoop::runEvery 17 not thread safe 18 test4: timer queue unittest 19 20Step 3: wakeup(), runInLoop(), EventLoopThread 21 test5: runInLoop(), runAfter() in loop thread 22 test6: runInLoop(), runAfter() in a different thread 23 24Step 4: Acceptor 25 test7: listen on port 9981, accept, send, and close 26 27Step 5: TcpServer, create TcpConnection 28 test8: use of TcpServer, discard server 29 30Step 6: TcpConnection passive close 31 32Step 7: TcpConnection read with Buffer, add receiveTime to read callback 33 test3: show receiveTime 34 test8: show receiveTime 35 36Step 8: TcpConnection write 37 test9: echo server 38 test10: data source server 39 40Step 9: write complete callback, tcp no delay, SIGPIPE 41 test11: chargen server 42 43Step 10: multithreaded TcpServer, EventLoopThreadPool 44 test8,9,10,11: support multithreads 45 46Step 11: Connector, TimerQueue::cancel() 47 test12: 48 49Step 12: TcpClient 50 test13: 51 52Step 13: epoll, EPoller 53 54