线程

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

 

转载于:https://www.cnblogs.com/YangWenYu-6/p/10267482.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值