乐观锁悲观锁及其使用场景

乐观锁

什么是乐观锁?

顾名思义, 就是什么都往好处想的锁, 总是认为被人来读数据不会对数据进行修改, 所以不上锁, 但是在更新的时候会判断一下在此期间别人有没有去更新这个数据

适用场景:

适用于写比较少的情况下

实现方式:

  1. 版本号机制: 在表中加入一个version字段, 表示该条记录被修改的次数, 当某个线程来读取数值时也会读取version, 在对其进行更新提交后会核对version字段是否和自己读到的version相同, 如果和刚才读到的version值不同那么会重试读-更新-查看version操作, 直到更新成功(此时让version+1)
  2. CAS算法

悲观锁

什么是悲观锁?

把任何情况都想到最坏, 每次拿到资源就会上锁, 此时其他想要使用该资源的线程会阻塞, 直到对资源使用完成才会释放该资源

适用场景:

适用于多写的场景

实现方式:

关系型数据库的行锁, 表锁, 写锁, 读锁, synchronized, ReentrantLock等都是悲观锁的实现

原文地址:https://www.cnblogs.com/katoMegumi/p/13888236.html