首页 > 其他 > 详细

乐观锁和悲观锁

时间:2020-03-16 19:52:11      阅读:59      评论:0      收藏:0      [点我收藏+]

  乐观锁和悲观锁是两种思想,并不局限于编程语言或数据库。

一、概念

  乐观锁:

    乐观锁在操作数据时非常乐观,认为别的线程不会同时修改数据。因此乐观锁不会加锁,只有在执行更新的时候判断一下再次期间其他线程是否

  修改了数据;如果其他线程修改了数据则放弃操作,否则执行操作。

  悲观锁:

    悲观锁在操作数据时比较悲观,认为其他线程会同时执行修改操作。因此操作数据期间对数据进行加锁,其他线程不能修改数据,直到操作完成才会释放锁。

 

二、实现方式

  悲观锁的实现方式就是加锁

    如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资源。

乐观锁和悲观锁

原文:https://www.cnblogs.com/yangyongjie/p/12505832.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!