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个任务拿到锁区执行任务,如果说互斥锁是合租房屋的人去抢一个厕所,那么信号量就相当于一群人去抢公共厕所,公共厕所有多个坑位,这意味着同一
时间可以有多个人上公共厕所,但是公共厕所容纳的人数是一定的,这便是信号量的大小