进程、线程和协程的对比
通俗描述:
1.有一个老板想要开个工厂生产某件商品,他需要花一些财力物力制作一条生产线,这个生产线上有很多的器件以及材料,这些所有的为了能够生产商品而准备的资源称之为:进程
2.只有生产线是不能够进行生产的,所以老板得找工人来进行生产,这个工人能够利用这些材料最终一步步的将商品做出来,这个来做事情的工人称之为:线程
3.这个老板为了提高生产效率,想到3种方法:
(1)在这条生产线上多招些工人,一起来做商品,这样效率是成倍增长,即单进程 多线程方式
(2)老板发现这条生产线上的工人不是越多越好,因为一条生产线的资源以及材料毕竟有限,所以老板又花了些财力物力购置了另一条生产线,然后再招些工人这样效果又再一步提高了,即 多线程 多进程方式
(3)老板发现,现在以及有了很多条生产线,并且每条生产线上已经有很多工人了(即程序是多进程的,每个进程中又有很多线程),为了再次提高效率,老板想了个损招,规定:如果某个员工在上班时临时没事或者在等待某些条件(比如等待材料或者等另一名工人做完才能再次工作),那么这个员工就利用这个时间去做其他的事情,那么也就是说:如果一个线程等待某些条件,可以充分利用这个时间去做其它事情,其实这就是:协程方式。
简单总结:
1.进程是资源分配的单位
2.线程是操作系统调度的单位
3.进程切换需要的资源很大,效率很低
4.线程切换需要的资源一般,效率一般(当然了在不考虑GIL(全局解释器锁)的情况下)
5.协程切换任务资源很小,效率高
6.多进程、多线程根据cpu核数不一样可能是并行的,但是协程是在一个线程中,所有是并发