一.悲观锁
悲观锁比较悲观,认为在使用数据的时候,一定会有别的线程来修改数据,因此在获取到数据后会先加锁,确保数据不会被别的线程给修改。
在Java中sychronized关键字或者Lock的实现类都是悲观锁,悲观锁的使用场景,适合使用在写操作比较多的场景。先加锁,在操作。确保了数据的一致性和安全性。
二.乐观锁
乐观锁比较乐观,认为在使用数据的时候,不会有其他线程来修改数据,不会添加锁。
在Java中乐观锁是通过无锁编程来实现的。只有在更新数据的时候才会去判断,之前有没有别的线程操作过这个数据。如果这个数据没有被更新,当前线程则会将自己修改的数据成功写入。如果这个数据已经被其他线程被更新,则会根据不同的实现方式进行不同的操作。比如放弃修改,重试抢锁。
乐观锁的判断规则:
1.版本号version
2.CAS算法