码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2020-10-29 09:28:42      阅读:16      评论:0      收藏:0      [点我收藏+]

标签:情况   zed   阻塞   syn   使用   读取   取数   其他   重试   

乐观锁

什么是乐观锁?

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

适用场景:

适用于写比较少的情况下

实现方式:

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

悲观锁

什么是悲观锁?

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

适用场景:

适用于多写的场景

实现方式:

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

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

标签:情况   zed   阻塞   syn   使用   读取   取数   其他   重试   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!