互斥锁、递归锁、读写锁、自旋锁

https://www.cnblogs.com/evenleee/p/11309156.html

互斥锁

共享锁的使用时互斥的,即一个线程获得资源的使用权后就会为该资源加锁,使用完后会将其解锁,所以在使用过程中有其它线程想要获得该资源的锁,那么它就会被阻塞陷入睡眠的状态,直到资源被解锁才会被唤醒,如果被阻塞的资源不止一个,那么他们都会被唤醒,但是获得资源使用权的是第一个被唤醒的线程,其它线程又陷入沉睡。

递归锁

同一个线程可以多次获得该资源锁,别的线程必须等待该线程释放所有次数的锁才能获得。

读写锁

读写锁拥有读状态加锁、写状态加锁、不加锁三种状态,… …

自旋锁

自旋锁是一种特殊的互斥锁,挡子源加锁后,其他线程想要再次加锁,此时线程不会被阻塞睡眠,而是陷入循环等待状态,循环检查资源持有者是否释放该资源,这样做的好处是减少了线程从睡眠到唤醒的资源消耗,但是会一直占用CPU资源。适用于资源的锁被持有的时间短,而不希望在线程的唤醒上花费太多资源的情况

目的
是为了保护一小段短小的临界区操作代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值