
关注
回答优化:
6、封装c++20协程,直接使用会很繁琐,封装成异步任务,开发者只需按照模板即可编写协程代码或者异步代码。当协程需要等待异步结果时,可以co_await等待。事件发生时,会唤醒当前协程继续执行。也提供了一些语法糖支持,wait_for,gather等。提供事件循环支持协程调度。事件循环:获取epoll_wait返回已就绪事件,定时器超时事件,将所有已就绪协程逐一调度执行。
8、协程相对于线程,更加轻量级。切换时不需要进入内核态,在用户态完成,切换时只需将协程状态(寄存器、变量、调用栈)保存到协程状态对象即可,其栈也比线程小。利用协程编写异步io代码更加方便,因为有co_await\co_yield\co_return这几个语法糖。线程编写则很割裂。
10、常见的池有:线程池、内存池、连接池(http\数据库)。共同的特点就是这些资源创建都需要一定的开销,如果每次使用都需要临时申请,cpu时间有相当部分用于创建这些资源。池就可以充分复用资源,降低资源创建开销。
线程池:系统启动时先创建若干线程,每个线程处于睡眠状态,当有任务时,唤醒其中一个线程来消化任务,任务完成,继续睡眠。充分复用线程,避免线程创建和销毁开销过大。(经典场景:一个连接一个线程,不可取,创建慢,连接数有上限)
内存池;预先申请一块较大的空间,后面需要申请内存,直接从这块内存划分,而不是通过系统调用重新申请。当用完释放内存时,将内存放回到池中,而不是直接释放。内存池的优点:有效降低内地申请和释放的开销。主要是减少系统调用的次数。以及能减少内存碎片。
连接池;同样是先创建,后面需要发送信息时直接复用池中连接。提高连接利用率。因为连接创建的开销还是比较大的。如果每次需要时才创建连接,用完就释放连接,这样用于真正数据的收发占比会比较低,因为连接创建需要握手,认证等等步骤。复用连接就能提高数据带宽的占比。例如:创建连接需要3ms,每次发数据固定1ms,池化与非池化对比明显。
查看原帖
点赞 评论
相关推荐
牛客热帖
更多
正在热议
更多
# 入职跑路最快的一次经历 #
29060次浏览 199人参与
# 你会为了工作牺牲生活吗? #
42441次浏览 343人参与
# 思朗科技求职进展汇总 #
50068次浏览 363人参与
# 国企秋招,你投了吗? #
14555次浏览 129人参与
# 海尔求职进展汇总 #
6941次浏览 33人参与
# 拿到offer之后,可以做些什么 #
28358次浏览 180人参与
# 携程求职进展汇总 #
616743次浏览 4548人参与
# ___岗狗都不干,我干! #
14773次浏览 113人参与
# 硬件开发岗知多少 #
16669次浏览 124人参与
# 机械只有转码才有出路吗? #
139409次浏览 1629人参与
# 材料人的华为红黑体验 #
33146次浏览 186人参与
# 校招谈薪技巧 #
43574次浏览 593人参与
# 通信硬件岗投递时间线 #
24964次浏览 88人参与
# 机械人,你最希望上岸的公司是? #
183271次浏览 1897人参与
# 央国企投递记录 #
111030次浏览 1451人参与
# 机械求职避坑tips #
64031次浏览 441人参与
# 为什么国企只招应届生 #
200018次浏览 1222人参与
# 你在职场中沾染到的“坏”习惯 #
12510次浏览 109人参与
# 互联网回暖,腾讯要招5000人! #
20802次浏览 584人参与
# 设计人如何选offer #
149450次浏览 793人参与
# 应届生应该先就业还是先择业 #
138571次浏览 724人参与