乐观锁和悲观锁
乐观锁和悲观锁是两种思想,并不局限于编程语言或数据库。
一、概念
乐观锁:
乐观锁在操作数据时持乐观态度,认为别的线程不会同时修改数据。因此乐观锁不会加锁,只有在执行更新的时候判断一下在此期间其他线程是否修改了数据;如果其他线程修改了数据则放弃操作,否则执行操作。
悲观锁:
悲观锁在操作数据时持悲观态度,认为其他线程会同时执行修改操作。因此操作数据期间对数据进行加锁,其他线程不能修改数据,直到操作完成才会释放锁。
二、实现方式
悲观锁的实现方式就是加锁
如Java中的synchronized关键字,ReentrantLock,分布式锁等对代码块进行加锁;或是MySQL中的排它锁(写锁)对数据进行加锁。
乐观锁的实现方式有:CAS机制和版本号机制
1、CAS:参考我的另一篇博客CAS:https://www.cnblogs.com/yangyongjie/p/10654084.html
2、版本号机制
版本号机制的思路是在数据中加一个字段version,表示该条数据的版本号,每当数据被修改,版本号加1。
当某个线程查询数据时,将该数据的版本号一并查出,在修改时,判断当前版本号与之前读取的版本号是否一致,如果一致才进行修改操作。
三、优缺点比较与适用场景
1、乐观锁相比悲观锁有很多限制
如:CAS只能保证单个变量操作的原子性,无法保证多个变量的原子性。版本号机制无法实现查询和修改不是一条记录或一张表的操作。
synchronized通过对整个代码块加锁则可以保证多个变量的原子性。
2、适用场景,按竞争激烈程度(出现并发冲突的概率)
1)竞争不激烈时:适用乐观锁,因为悲观锁会锁住代码块或数据行,导致其他线程无法访问并阻塞,影响并发;另外,悲观锁的加锁和释放锁也需要额外的资源开销。
如写操作多的场景
2)竞争激烈时:适用悲观锁,因为乐观锁修改失败会不断重试,浪费CPU资源。
如读操作多的场景
END.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类