0. 前置知识
- asio中io_server是一个很重要的东西,任何操作都需要它,在异步编程的时候,需要io_server.run()启动, 有点像事件驱动模型中的 event.loop().(原理不一样,只是说编程类似)
1. 一个io_server和一个线程
- 就是主线程一个io_server.run(),这样加入这里面有三个回调函数调用,如果第一个响应了,正在处理过程中,第二个回调函数响应,要等第一个执行完才行.
2. 一个io_server和多个线程
- 启动多个线程,每个线程都调用 io_server.run(), 这里各线程中的io_server是同一个
- 这样碰到上面那种情况,第二个回调函数就会找一个空闲线程去运行,会提高效率
3. 多个io_server和多个线程
- 就是每个线程有自己的io_server, 这样和第一种情况有些类似, 不过可以对不同的套接字绑定到不同的线程io_server上, 然后各线程只处理自己关注的套接字
- 目前个人感觉还是第二种情况更好用