看了一个boost高并发网络框架,但是没搞懂部分代码。求解
首先放上代码的网址:
https://blog.csdn.net/merryken/article/details/9047371#10006-weixin-1-52626-6b3bffd01fdde4900130bc5a2751b6d1
有两个问题, class io_service_pool; 里面的 start()方法应该是用多个线程对同一个端口进行监听。 然后join()的时候只有一个线程join()了。 而且把断点卡在那里一直没返回(那应该就是这个线程一直在 "监听->获取连接->处理数据->连接关闭->重新监听" 。所有没返回 ?!) 那这个for循环的用处是干嘛呢? 用于日后可以关闭部分线程?!
还有就是这样开一堆线程监听并处理数据,比起只有一个线程异步监听,然后再开多线程处理数据两者有什么优缺点吗?! 如果一个线程异步监听, 处理数据用多线程。应该单线程组包成功后再用多线程处理数据,还是收到连接后直接在多线程组包后直接处理数据 更高效率?!