zoukankan      html  css  js  c++  java
  • 乐观锁与悲观锁

    乐观锁 悲观锁——是一种思想。可以用在很多方面。

    数据库方面:
    悲观锁就是for update(锁定查询的行)
    乐观锁就是 version字段(比较跟上一次的版本号,如果一样则更新,如果失败则要重复读-比较-写的操作。)

    JDK方面:
    悲观锁就是sync
    乐观锁就是原子类(内部使用CAS实现)

    本质来说,就是悲观锁认为总会有人抢我的。
    乐观锁就认为,基本没人抢。

    乐观锁-不加锁
                总认为不会发生并发问题,每一次取数据时总认为其他线程不会对该数据进行更改,但是在更新时会判断其他线程在这之前有没有对该数据进行修改,
                数据库当中常用方案:版本号控制

        

    乐观并发控制相信事务之间的数据竞争概率非常小,因此尽可能直接操作,提交的时候才去锁定,不会产生任何锁和死锁。

     悲观锁
                总是假设最坏的情况,每次取数据时,都会认为其他线程会对该数据进行修改,所以会进行加锁
                其他线程访问的时候会阻塞等待,例如在数据库当中可以使用行锁,表锁以及读写锁等方式实现     

       在Java中synchronized就是悲观锁的表现

    在效率上,处理加锁的机制会让数据库产生额外的开销,还会有死锁的可能性。降低并行性,一个事务如果锁定了某行数据,其他事务就必须等待该事务处理完才可以处理那行数据。

    悲观锁的实现方式:悲观锁的实现,依靠数据库提供的锁机制。在数据库中,悲观锁的流程如下:

    • 在对数据修改前,尝试增加排他锁。
    • 加锁失败,意味着数据正在被修改,进行等待或者抛出异常。
    • 加锁成功,对数据进行修改,提交事务,锁释放。
    • 如果我们加锁成功,有其他线程对该数据进操作或者加排他锁的操作,只能等待或者抛出异常。

    总结

    1. 乐观锁不是真的加锁,效率高,但是要控制好锁的力度。
    2. 悲观锁依赖数据库锁,效率低。
  • 相关阅读:
    OpenCASCADE Chamfer 3D Basics
    OpenCASCADE Chamfer 2D
    .NetCore 连接 Oracle 数据库,直接C# 或者 ORM框架(EFCore、XPO)
    心内科疾病指南
    HttpClient 调用 RestAPI 接口的用法
    在 Blazor 应用中使用 DevExtreme widgets
    2021 最近一次检查甘油三脂,验证苯扎贝特的效果。
    紫鹊界本味湘菜,
    如何Rest接口获取网上的股票数据,有哪些资源?-- 推荐Tushare金融数据
    优秀常用的「资源搜索网站」,收藏
  • 原文地址:https://www.cnblogs.com/chx9832/p/12567146.html
Copyright © 2011-2022 走看看