详细介绍 进程、线程和协程的区别
详解 进程、线程和协程的区别
首先,给出“进程、线程和协程”的特点:
- 进程:拥有自己独立的堆和栈,既不共享堆,也不共享栈,进程由操作系统调度;
- 线程:拥有自己独立的栈和共享的堆,共享堆,不共享栈,标准线程由操作系统调度;
- 协程:拥有自己独立的栈和共享的堆,共享堆,不共享栈,协程由程序员在协程的代码里显示调度。
接下来,以一个形象的例子,进一步讲述“进程、线程和协程”三者之间的区别:
假设有一个单核的操作系统,系统上没有其它的程序需要运行,现有两个线程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秒的时间。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!