互斥锁(Lock),递归锁(Rlock),信号量(Samaphore)

1.互斥锁:牺牲了效率,保证了数据安全,缺点:acqueire后其他进程必须等到该进程release后才能继续拿到锁,可能出现死锁情况。

 

 

2.递归锁

这个Rlock 内部有一个Lock 和counter   counter是用来记录acquire的次数,可以使得资源可以被多次acquire,直到一个线程所有的

acquire都被release,其他的线程才能获得资源,同步锁和递归锁得区别:递归锁可以连续acquire多次,而互斥锁只能acquire一次

总结:Rlock可以多次acquire,每次acquire就相当于counter + 1, 只要counter 不为 0 ,别的进程就无法拿到我的锁,就是锁已经有主人了,除非等我释放了该锁,counter - 1 = 0 这个时候 其他线程才可以 拿到锁。

 

3.信号量

信号量也是一把锁,可以指定信号量为5,对比互斥锁同一时间只能有一个任务抢到锁去执行,信号量同一时间可以有5个任务拿到锁区执行任务,如果说互斥锁是合租房屋的人去抢一个厕所,那么信号量就相当于一群人去抢公共厕所,公共厕所有多个坑位,这意味着同一

时间可以有多个人上公共厕所,但是公共厕所容纳的人数是一定的,这便是信号量的大小

 

转载于:https://www.cnblogs.com/jingandyuer/p/11413639.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值