进程:资源分配单位
线程:cpu执行单位(实体)
线程的创建和销毁的开销特别小
线程的两种创建方式:(重点)
1. From threading import Thread Def f1(n): Print(n) main T = Thread(target=f1,args=(1,)) T.start()
2. Class MyThread(Thread): Def __init__(self,n): Super().__init__() Self.n = n Def run(self): Pass Main T = MyThread(5) T.start()
线程锁
锁:牺牲了效率,保证了数据安全(重点)
死锁现象:出现在锁嵌套的时候,双方互相抢对方已经拿到的锁,导致双方互相等待,天长地久永不分离,死锁现象(重点)
递归锁:解决死锁现象(重点)
Rlock 首先本身就是个互斥锁,维护了一个计数器,每次acquire就+1,release就-1,当计数器为0的时候,大家才能抢这个锁
守护线程(**)
守护线程:等待所有非守护线程的结束才结束
守护进程:主进程代码运行结束,守护进程就随之结束
GIL锁
cpython解释器上的一把互斥锁