简述 python线程、进程、协程

进程:

一个运行的程序就是一个进程,没有运行的代码叫程序。进程是系统分配资源的最小单位,数据不共享,开销大

线程:

调度执行的最小单位,不能独立存在 依赖于进程,数据可以共享,但是要保证同一时刻只能有一个线程在执行。

协程:

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

协程的优缺点:
优点:
  上下文切换消耗小
  方便切换控制流,简化编程模型
  高并发,高扩展性,低成本
  
缺点:
	无法利用多核
	进行阻塞操作时会阻塞掉整个程序
	单纯的协程是没有意义的,只是人为的控制执行一下这个,执行一下那个,如果	想监测是否有IO操作,需要结合IO多路复用

为什么要用进程+协程

协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈。

在并发编程中,协程与线程类似,每个协程表示一个执行单元,有自己的本地数据,与其它协程共享全局数据和其它资源。

因为协程是用户自己来编写调度逻辑的,对CPU来说,协程其实是单线程,所以CPU不用去考虑怎么调度、切换上下文,这就省去了CPU的切换开销,所以协程在一定程度上又好于多线程。
需要注意的是我们在这里不使用进程池multiprocessing.Pool来控制进程数量的原因是multiprocessing.Pool和gevent有冲突不能同时使用,有兴趣可以探究底层。

进程与线程的关系

(1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程

(2)资源分配给进程,进程是程序的主体,同一进程的所有线程共享该进程的所有资源

(3)cpu分配给线程,即真正在cpu上运行的是线程

(4)线程是最小的执行单元,进程是最小的资源管理单元

线程中的互斥锁,死锁

互斥锁的作用:lock互斥锁实现防止全局变量的互相争抢
死锁:在线程间共享多个资源的时候,如果两个线程分别占有一部分资源并且同时等待对象的资源时,就会造成死锁。
互斥锁提供一个可以在同一时间,只让一个线程访问临界资源的操作接口。上锁之后会被阻塞,等待锁的释放。
线程互斥锁是Python 代码层面的锁,解决python程序中线程共享资源的问题。

GIL锁

说到线程的互斥锁,就不得不说一下GIL锁。GIL Global Interperter Lock 全局解释器,GIL 不是python语言的特性 是Cpython中的一个概念。
GIL是python解释层面的锁,解决解释器中多个线程的资源竞争问题。
GIL对程序的影响:GIL锁在遇到IO等待时,会释放GIL锁,可以提高python中IO密集型程序的效率。
GIL影响的解决办法:如果需要大量的计算利用缩合CPU资源,可以使用多进程来解决

什么时候会释放锁:

1.当时间片耗尽时,会释放GIL锁
2.当线程遇到io时等待时,会释放GIL锁
3.当解释器在执行代码时,达到一定阀值 默认是100条字节码

如有概念问题,欢迎私信指正,谢谢。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值