协程这么好,它能完全代替线程么?
好多问题呀,开始回答或者提问前,其实可以看看问题本身是不是有问题,像黄执中一样。
------
(相关资料图)
这个问题首先前提就有问题,谁说协程那么好的?任何技术肯定都有自己的适用场景,这种通用层面的技术则更是了。
协程本质上就是由用户代码主动在某个时间点出让 CPU,可以在任何一行出让,当然语言层或框架层的协程一般会在原本是阻塞函数的调用内部,让出 CPU 资源,不阻塞当前线程。
当然像 go 这种协程做的特别牛逼的,牛逼到它自己都不想承认自己是协程的语言,就另说了。
所以协程一般适用于 IO 密集型的高并发场景。
你要说就完全 CPU 密集型计算,那还不如开你 CPU 核数那么多线程呢,开了协程反而不能并行了,还多了协程间切换的损耗。
所以协程那么好,这句话就可以否了,同时也顺便拿出了一个场景,说明用协程替换线程是负优化的,自然协程也不能完全替换线程。
------
再有,刚刚是站在应用程序角度考虑,要分场景看是使用协程还是线程。再从操作系统层面考虑,协程就根本无法替代线程了。
你想,协程需要自己主动出让 CPU 资源,那要是操作系统使用协程来运行应用程序,那万一应用程序自己一直不出让 CPU,也不调用能产生阻塞操作进而间接出让 CPU 的代码,那不就坏事了。
再有,协程本身的优势在于切换成本小,本质是因为栈小,而且也不需要切换页表。
那要是操作系统真的拿协程来跑多应用程序,这些优势也就不复存在了,而且如果协程实现在了内核态,本身从用户态陷入内核态的切换也少不了。
所以本来协程有的优势,在这里全没了,还极大增加了不公平性。
------
最后,这俩事情本身就不好讨论替换这一说,因为他们本质都不一样。
协程说白了就是一段串行的指令流,只不过中间哪个地方往哪跳的逻辑,被封装在了 "协程" 这个概念里而已。
再者,协程本身也是要跑在线程中的,需要有载体,他们二者本身就是相辅相成的关系,何来替代呢,更别说完全替代了。
有时候,了解清楚一项技术的本质,就能更好看清这些问题的荒诞了。
今天阳了躺在床上实在无聊,就挑了个知乎上的问题回答了一下,看好多回答都没说在点子上,就码了这些字,感兴趣的同学可以点开阅读原文看看。
关键词: 应用程序
相关新闻
- 协程这么好,它能完全代替线程么?
- 今日热文:国家药监局:抗原检测会存在“假阴性”或“假阳性”情况
- 特斯拉柏林超级工厂 Model Y 周产量突破 3000 辆
- 微速讯:安道设计董事会秘书韩宁辞职2022上半年公司亏损177.97万
- 唐源电气董秘回复:公司上市至今控股股东未曾减持公司股份,其对公司的发展充满信心_环球报道
- 全球百事通!博彩股盘初集体回落,永利澳门(01128.HK)、美高梅中国(02282.HK)等跌幅靠前
- 许昌市魏都区人民法院民二庭:党建引领 护企安商
- 环球视点!班凯罗晒KD签名球衣 阿杜:我没想过去争夺MVP
- 一渔船在珠海万山海域被撞沉 8名船员全部获救-世界球精选
- 【天天速看料】承德电信总经理梁博文上任一年 前任被调到业绩规模更大的地市公司
- 新动态:本周盘点(12.12-12.16):国睿科技周跌4.22%,主力资金合计净流出1660.74万元
- 沙钢股份:12月15日获融资买入319.66万元|焦点要闻
- 世界今热点:舆情追踪|益阳市大通湖区锦程宝元有限公司新增严重违法信息
- 开开实业(600272)12月15日主力资金净买入268.05万元-速递
- “第一支箭”4万亿授信花落谁家?100多家房企受益
- 大酒店(00045.HK):González Morales获委任为非执行董事 焦点快看
- 我市着力探索农业供给侧结构性改革路径
- 世界聚焦:芯碁微装(688630)12月13日主力资金净卖出1176.68万元
- 北京经开区复工进行时:审批不过夜 百强企业100% 复工复产|每日快看
- 热文:光迅科技:12月12日获融资买入541.21万元,占当日流入资金比例16.1%
- 明阳电路: 深圳明阳电路科技股份有限公司向不特定对象发行可转换公司债券预案
- 天天快报!新学期,这些“宝藏课程”让校园生活更多彩
- 全力冲刺!各地加大助企纾困力度-当前最新
- 川恒股份(002895)12月8日主力资金净买入8380.21万元_环球新资讯