进程:资源分配单位
线程: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解释器上的一把互斥锁

 


posted on 2019-01-14 16:20  YangWenYu  阅读(140)  评论(0编辑  收藏  举报