• 首页
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案
目录

协程和纤程的区别是什么

协程和纤程的区别主要在于调度。这两个单词都翻译得不错,coop协作,co就是协的词根,coroutine翻译成协程很巧妙, fiber是纤维,翻译成纤程,对应的thread/线程,process/进程。

一、协程和纤程的区别

协程和纤程的区别主要在于调度。这两个单词都翻译得不错,coop协作,co就是协的词根,coroutine翻译成协程很巧妙, fiber是纤维,翻译成纤程,对应的thread/线程,process/进程,这几个单词翻译得都比较巧妙。 说回coroutine和fiber. coroutine和fiber的差异点在于,两者的调度不一样,异步api在结果出来前,会释放当前线程,那么在此期间,当前线程就能去搞其他的计算活动,那一个最原始的异步api,一般是以带有callback的形式出现,但是callback有一个问题,就是写起来会变得混乱,因为callback要嵌套进参数里面去。

最开始的stackfull协程,本质上跟微软的Fiber是一样的。只不过,寄存器现场的保存和回复,一般不是由操作系统的API来提供而已。保存和恢复代码百花齐放,我至少知道五种以上知名的代码。除了基本的栈空间,寄存器现场,其他数据就可有可无了。很多协程是肯定不支持TLS数据的,所以,在使用某些函数上就要针对协程的特性来决定能不能用。或者协程库妥协为单线程执行。

延伸阅读:

二、协程是什么

协程(Coroutines)是一种比线程更加轻量级的存在。协程完全由程序所控制(在用户态执行),带来的好处是性能大幅度的提升。

 一个操作系统中可以有多个进程;一个进程可以有多个线程;同理,一个线程可以有多个协程。

协程是一个特殊的函数,这个函数可以在某个地方挂起,并且可以重新在挂起处继续运行。

 一个线程内的多个协程的运行是串行的,这点和多进程(多线程)在多核CPU上执行时是不同的。 多进程(多线程)在多核CPU上是可以并行的。当线程内的某一个协程运行时,其它协程必须挂起。

以上就是关于协程和纤程的区别的内容希望对大家有帮助。

相关文章