协程这么好,它能完全代替线程么?-天天聚看点
好多问题呀,开始回答或者提问前,其实可以看看问题本身是不是有问题,像黄执中一样。
------
(资料图片)
这个问题首先前提就有问题,谁说协程那么好的?任何技术肯定都有自己的适用场景,这种通用层面的技术则更是了。
协程本质上就是由用户代码主动在某个时间点出让 CPU,可以在任何一行出让,当然语言层或框架层的协程一般会在原本是阻塞函数的调用内部,让出 CPU 资源,不阻塞当前线程。
当然像 go 这种协程做的特别牛逼的,牛逼到它自己都不想承认自己是协程的语言,就另说了。
所以协程一般适用于 IO 密集型的高并发场景。
你要说就完全 CPU 密集型计算,那还不如开你 CPU 核数那么多线程呢,开了协程反而不能并行了,还多了协程间切换的损耗。
所以协程那么好,这句话就可以否了,同时也顺便拿出了一个场景,说明用协程替换线程是负优化的,自然协程也不能完全替换线程。
------
再有,刚刚是站在应用程序角度考虑,要分场景看是使用协程还是线程。再从操作系统层面考虑,协程就根本无法替代线程了。
你想,协程需要自己主动出让 CPU 资源,那要是操作系统使用协程来运行应用程序,那万一应用程序自己一直不出让 CPU,也不调用能产生阻塞操作进而间接出让 CPU 的代码,那不就坏事了。
再有,协程本身的优势在于切换成本小,本质是因为栈小,而且也不需要切换页表。
那要是操作系统真的拿协程来跑多应用程序,这些优势也就不复存在了,而且如果协程实现在了内核态,本身从用户态陷入内核态的切换也少不了。
所以本来协程有的优势,在这里全没了,还极大增加了不公平性。
------
最后,这俩事情本身就不好讨论替换这一说,因为他们本质都不一样。
协程说白了就是一段串行的指令流,只不过中间哪个地方往哪跳的逻辑,被封装在了 "协程" 这个概念里而已。
再者,协程本身也是要跑在线程中的,需要有载体,他们二者本身就是相辅相成的关系,何来替代呢,更别说完全替代了。
有时候,了解清楚一项技术的本质,就能更好看清这些问题的荒诞了。
今天阳了躺在床上实在无聊,就挑了个知乎上的问题回答了一下,看好多回答都没说在点子上,就码了这些字,感兴趣的同学可以点开阅读原文看看。
关键词: 应用程序
- 协程这么好,它能完全代替线程么?-天天聚看点
- 美股异动 | 雾芯科技(RLX.US)涨近7% 总市值升至39亿美元_最新消息
- 环球看热讯:招商房托完成境内外再融资和贷款置换 已提取超过40亿元贷款
- 环球速看:丰立智能:公司主要产品包括钢齿轮、精密减速器及零部件、精密机械件等
- 年内首现上市首日破发转债,38只转债基金今年全部负收益-天天快看点
- 小摩增持康希诺生物(06185.HK)约52.80万股 每股作价约92.15港元
- 环球新资讯:2023-2028年中国电子显微镜行业市场深度分析及投资潜力预测报告
- 信阳市第三期月开工竞赛活动启动仪式在息县举行 今日关注
-
成都12月19日零时启动重污染天气橙色预警
据成都市大气水土壤污染防治“三大战役”领导小组办公室消息,根据省污染防治攻坚办12月16日发布的重污染天气预警信息,按照《成都市重污染天
-
【全球播资讯】两岸逾500家台企参展东莞台博会 展会聚焦数字经济
中新网广东新闻8月19日电(李映民李纯)2022第十三届东莞台湾名品博览会将于9月1日至9月4日在广东省东莞市举行。记者19日从本届博览会组委会获悉
-
每日简讯:海航控股: 海航控股:2022年11月主要运营数据公告
临时公告证券代码:600221、900945 证券简称:海航控股、海控 B 股 编号:临 2022-141
-
贵绳股份(600992)12月16日主力资金净买入127.72万元
截至2022年12月16日收盘,贵绳股份(600992)(600992)报收于23 45元,上涨4 45%,换手率7 57%,成交量18 55万手,成交额4 2
X 关闭
X 关闭