乐观锁
定义
乐观锁采用乐观的思想处理数据,在每次读取数据时都认为别人不会修改该数据,所以不会加锁,但在更新时会判断在此期间有没有别人更新该数据。
实现
具体流程:比较当前版本号与上一次的版本号,如果版本号一致则更新;如果版本号不一致,则重复进行读、比较、写操作。
Java中乐观锁大部分都是通过CAS(Compare And Swap,比较和交换)操作实现,CAS是一种原子更新操作,在对数据操作之前首先会比较当前值跟传入的值是否一致,如果一致则更新,否则不执行更新操作,直接返回失败状态。
悲观锁
定义
悲观锁采用悲观的思想处理数据,在每次读取数据时都会认为别人会修改数据,所以每次在读写数据时都会加锁,这样在别人想写这个数据时就会发生阻塞,等待直到获取锁。
实现
Java中悲观锁大部分基于AQS(Abstract Queued Synchronized,抽象的队列同步器)架构来实现。AQS中定义了一套多线程访问共享资源的同步框架,许多同步类的实现都依赖于它。例如常见的Synchronized、ReentrantLock、Semaphore、CountDownLatch等。该框架下的锁会先尝试以CAS乐观锁去获取锁,如果获取不到,则会转换为悲观锁(如ReentrantLock重入锁)。
本文介绍了Java中乐观锁和悲观锁的概念及其实现方式。乐观锁基于CAS操作,适用于读多写少场景;悲观锁基于AQS架构,适合写多场景。两者通过不同的策略解决并发问题。
1530

被折叠的 条评论
为什么被折叠?



