显式锁
1 ReentrantLock 实现了 Lock 接口,并提供了与 synchronized 相同的互斥性和内存可见性。还提供了可重入的加锁寓意。
内置锁中,死锁是一个严重的问题,主要原因是多个获取锁的顺序形成了一个环,恢复程序的唯一方法是重启程序,而防止死锁的唯一方法就是在构造程序时避免出现不一致的锁顺序。
可定时的或可轮训的锁提供了另外的解决方法。
2 锁的公平性:是否按照请求顺序来获得锁。
对于锁竞争比较激烈、每个线程获得锁后处理时间比较短的话使用非公平的锁比较好。因为要唤醒因获取该锁而挂起的线程并不是即时的,需要回复上下文等一系列操作,如果此时另一个线程来获取该锁,并一会就结束,那么非公平锁会有更高的效率。
对于获取锁不激烈,即每个获取锁的间隔比较长,而持有所的时间相对较长,此时使用公平锁更好。
3 ReentrantLock 与 synchronized 比较
在大多数情况下使用 synchronized 比较好,只有 synchronized 不能满足需要时使用 ReentrantLock
ReentrantLock 优点
- 可以是等待可中断的锁:持有锁线程长时间持有锁,等待线程在规定时间外放弃获得锁。
- 公平锁:ReentrentLock 可以实现公平锁
- 绑定多个条件:ReentrantLock 可以实现绑定多个条件的锁。
4 ReadWriteLock
当读取操作远多于写入操作时,使用读写锁可以提高并发性。
学习过程中,难免出错。如果您在阅读过程中遇到不太明白,或者有疑问。欢迎指正...联系邮箱crazyCodeLove@163.com
如果觉得有用,想赞助一下请移步赞助页面:赞助一下
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)