回答优化: 6、封装c++20协程,直接使用会很繁琐,封装成异步任务,开发者只需按照模板即可编写协程代码或者异步代码。当协程需要等待异步结果时,可以co_await等待。事件发生时,会唤醒当前协程继续执行。也提供了一些语法糖支持,wait_for,gather等。提供事件循环支持协程调度。事件循环:获取epoll_wait返回已就绪事件,定时器超时事件,将所有已就绪协程逐一调度执行。 8、协程相对于线程,更加轻量级。切换时不需要进入内核态,在用户态完成,切换时只需将协程状态(寄存器、变量、调用栈)保存到协程状态对象即可,其栈也比线程小。利用协程编写异步io代码更加方便,因为有co_await\co_yield\co_return这几个语法糖。线程编写则很割裂。 10、常见的池有:线程池、内存池、连接池(http\数据库)。共同的特点就是这些资源创建都需要一定的开销,如果每次使用都需要临时申请,cpu时间有相当部分用于创建这些资源。池就可以充分复用资源,降低资源创建开销。 线程池:系统启动时先创建若干线程,每个线程处于睡眠状态,当有任务时,唤醒其中一个线程来消化任务,任务完成,继续睡眠。充分复用线程,避免线程创建和销毁开销过大。(经典场景:一个连接一个线程,不可取,创建慢,连接数有上限) 内存池;预先申请一块较大的空间,后面需要申请内存,直接从这块内存划分,而不是通过系统调用重新申请。当用完释放内存时,将内存放回到池中,而不是直接释放。内存池的优点:有效降低内地申请和释放的开销。主要是减少系统调用的次数。以及能减少内存碎片。 连接池;同样是先创建,后面需要发送信息时直接复用池中连接。提高连接利用率。因为连接创建的开销还是比较大的。如果每次需要时才创建连接,用完就释放连接,这样用于真正数据的收发占比会比较低,因为连接创建需要握手,认证等等步骤。复用连接就能提高数据带宽的占比。例如:创建连接需要3ms,每次发数据固定1ms,池化与非池化对比明显。