Python中的进程,线程,协程异同点

一、进程

进程是资源(CPU、内存等)分配的基本单位,它是程序执行时的一个实例。程序运行时系统就会创建一个进程,并为它分配资源,然后把该进程放入进程就绪队列,进程调度器选中它的时候就会为它分配CPU时间,程序开始真正运行。

二、线程

线程是进程的一个执行流,是CPU调度和分派的基本单位,一个进程可以由很多个线程组成,线程间共享进程的所有资源,每个线程有自己的堆栈和局部变量。线程由CPU独立调度执行,在多CPU环境下就允许多个线程同时运行。同样多线程也可以实现并发操作,每个请求分配一个线程来处理。

进程和线程的区别和优劣:
1、执行单位上:进程是资源(CPU、内存等)分配的基本单位,线程是进程的一个执行流,是CPU调度和分派的基本单位。
2、资源开销:进程有自己的独立地址空间,每启动一个进程,系统就会为它分配地址空间,这种操作非常昂贵。而线程是共享进程中的数据的,使用相同的地址空间,因此CPU切换一个线程的花费远比进程要小很多,只是花费少部分的cpu资源,同时创建一个线程的开销也比进程要小很多。
3、切换效率:进程,创建销毁、切换复杂,速度慢。线程,创建销毁、切换简单,速度很快
4、通信:线程之间的通信更方便,同一进程下的线程共享全局变量、静态变量等数据,而进程之间数据不共享,需要通过队列等方式来实现数据共享。
5、可靠性:但是多进程程序更健壮,多线程程序只要有一个线程死掉,整个进程也死掉了,而一个进程死掉并不会对另外一个进程造成影响,因为进程有自己独立的地址空间。所以,进程可靠性更高。

三、协程

协程是一种用户态微量级的线程,协程是程序级别的,由程序员根据需要自己调度,协程能保留上一次调用时的状态(即所有局部状态的一个特定组合),每次过程重入时,就相当于进入上一次调用的状态,换种说法:进入上一次离开时所处逻辑流的位置。

协程的优缺点
相比于线程的优点:
1、可控性强,方便切换,由程序员自主调度
2、高并发+高扩展性+低成本
3、无需线程上下文切换的开销
4、无需原子操作锁定及同步的开销
缺点:
1.无法利用多核资源:协程的本质是个单线程,它不能同时将 单个CPU 的多个核用上,协程需要和进程配合才能运行在多CPU上.当然我们日常所编写的绝大部分应用都没有这个必要,除非是cpu密集型应用。
2.进行阻塞(Blocking)操作(如IO时)会阻塞掉整个程序

四、python中线程GIL锁

Python语言和GIL没有半毛钱关系。仅仅是由于历史原因在Cpython虚拟机(解释器),难以移除GIL.每个线程在执行的过程都需要先获取GIL,保证同一时刻只有一个线程可以执行代码。
python中即使有threading模块,也可以进行调用,但创造出来的多线程并不是真正意义上的多线程.
由于GIL的存在保证了同一时间只有一个线程可以执行代码,这就导致了即使使用多线程也不能实现并行,不能充分利用多核cpu。

GIL锁的解决方法:
1:更换解释器 比如使用jpython(java实现的python解释器),python默认的解释器是Cpython虚拟机.
2:使用多进程完成多任务的处理

五、进程、线程、协程的应用场景

python中只有进程可以是并行的,线程由于GIL的存在无法并行,协程是一种微线程存在于主线程中不存在并行。三者都能解决并发只是效率不同。
cpu操作密集型,如:需要大量的科学计算,要充分利用到多核cpu,使用进程。
常见的浏览器、Web服务(现在写的web是中间件帮你完成了线程的控制),web处理请求使用多线程。
io密集型,在处理像IO操作等可能引起阻塞的这类任务的时候 使用单线程和协程时效率更高。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值