当前位置:主页 > 查看内容

详细介绍 进程、线程和协程的区别

发布时间:2021-04-30 00:00| 位朋友查看

简介:详解进程、线程和协程的区别 首先,给出“进程、线程和协程”的特点: 进程 :拥有自己独立的堆和栈,既不共享堆,也不共享栈,进程由操作系统调度; 线程 :拥有自己独立的栈和共享的堆,共享堆,不共享栈,标准线程由操作系统调度; 协程 :拥有自己独立的……

详解 进程、线程和协程的区别

首先,给出“进程、线程和协程”的特点:

  • 进程:拥有自己独立的堆和栈,既不共享堆,也不共享栈,进程由操作系统调度;
  • 线程:拥有自己独立的栈和共享的堆,共享堆,不共享栈,标准线程由操作系统调度;
  • 协程:拥有自己独立的栈和共享的堆,共享堆,不共享栈,协程由程序员在协程的代码里显示调度。

接下来,以一个形象的例子,进一步讲述“进程、线程和协程”三者之间的区别:

假设有一个单核的操作系统,系统上没有其它的程序需要运行,现有两个线程 A 和 B,A 和 B 在单独运行时都需要 10 秒来完成自己的任务,而且任务都是运算操作,线程 A 和 B 之间没有竞争和共享数据的问题。现在让 A 和 B 两个线程并行,则操作系统会不停的在 A 和 B 两个线程之间切换,达到一种伪并行的效果。

如果操作系统切换的频率是每秒一次,切换的成本是 0.1 秒(主要是栈切换),则总共需要 20 + 19 * 0.1 = 21.9 秒;如果使用协程的方式,可以先运行协程 A,A 结束的时候让位给协程 B,只发生一次切换,则总共需要 20 + 1 * 0.1 = 20.1 秒。如果操作系统是双核的,而且线程是标准线程,那么线程 A 和 B 可以达到真的并行,则总时间为 10 秒;而协程的方式仍然需要 20.1 秒的时间。

感谢阅读,希望能 帮助到大家,谢谢大家对本站的支持!


本文转载自网络,原文链接:https://m.jb51.net/article/109700.htm
本站部分内容转载于网络,版权归原作者所有,转载之目的在于传播更多优秀技术内容,如有侵权请联系QQ/微信:153890879删除,谢谢!
上一篇:关于Git远程与本地冲突的解决方法 下一篇:没有了

推荐图文


随机推荐