首页 > 编程语言 > 详细

简述 进程、线程、协程的区别 以及应用场景?

时间:2019-12-17 10:00:33      阅读:282      评论:0      收藏:0      [点我收藏+]

1.进程是计算器最小资源分配单位 .

2.线程是CPU调度的最小单位 .

3.进程切换需要的资源很最大,效率很低 .

4.线程切换需要的资源一般,效率一般(当然了在不考虑GIL的情况下) .

5.协程切换任务资源很小,效率高(协程本身并不存在,是程序员通过控制IO操作完成) .

6.多进程、多线程根据cpu核数不一样可能是并行的,但是协程是在一个线程中 所以是并发.

 

进程:

一个运行的程序(代码)就是一个进程,没有运行的代码叫程序,进程是系统资源分配的最小单位,进程拥有自己独立的内存空间,所以进程间数据不共享,开销大。

线程:

调度执行的最小单位,也叫执行路径,不能独立存在,依赖进程存在一个进程至少有一个线程,叫主线程,而多个线程共享内存(数据共享,共享全局变量),从而极大地提高了程序的运行效率。

协程:

是一种用户态的轻量级线程,协程的调度完全由用户控制。

协程拥有自己的寄存器上下文和栈。

协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈,直接操作栈则基本没有内核切换的开销,

可以不加锁的访问全局变量,所以上下文的切换非常快。

简述 进程、线程、协程的区别 以及应用场景?

原文:https://www.cnblogs.com/Rivend/p/12052550.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!