`

乐观锁之版本号机制和CAS

 
阅读更多

乐观锁:每次去拿数据的时候,都认为别人不会修改,不会加锁,但在更新的时候会去判断一下,此期间别人有没有更新数据,版本号机制和CAS算法就用到乐观锁,参考了https://blog.csdn.net/u011381576/article/details/79922538;

  举一个版本号的例子,

  数据表中除了数据还有一个version字段,更新数据时version字段会加一,

  假设线程A在读取数据和version(version = 1)的期间,有另一个线程B也读取了version(version = 1),

  线程A修改数据,更新version(version = 2),提交更新时,在更新version前读取的version(version = 1)和当前数据表中的version(version = 1)相同,则更新成功

  线程B也修改数据,更新version(version = 2)提交更新时,由于读取时version = 1 而当前数据表version = 2 不相等,则更新失败, 

  CAS 是什么?

  CAS(compare and swap) 比较并交换,有三个操作数,内存地址V ,预期值B,要替换得到的目标子A;

  CAS指令执行时,比较内存地址V与预期值B是否相等,若相等则将A赋给B,(不相等则会循环比较直到相等)整个比较赋值操作是一个原子操作;

  CAS有三个缺点

  1,CAS自旋操作:当内存地址V与预期值B不相等时会一直循环比较直到相等,

  2,只能保证一个共享变量的原子操作,

  3,出现ABA问题:如果内存值初V次读取的时候为A,在将要赋值的时候再次检查还是A,能说明V没有改变过吗?

  有一种可能时当读取内存值V的时候时A,有一个线程将A改为B,后有改为A,CAS会误认为内存值V没有改变,这称为CAS操作的ABA问题;

分享到:
评论

相关推荐

    悲观锁和乐观锁.md

    所谓乐观锁,重视假设最好的情况,每次去拿数据都认为别人不会修改,所以不会上锁,但是会在更新时判断一下在此期间这个数据有没有更改,使用版本号机制和CAS算法实现,乐观锁适用于多读的应用类型,这样可以提高...

    面试必备之乐观锁与悲观锁.pdf

    乐观锁的实现方式主要有两种:版本号机制和CAS算法。 **1. 版本号机制**: 版本号机制是通过在数据表中添加一个版本号字段来实现的。每当数据被修改时,版本号字段都会增加。在线程A要更新数据时,会同时读取数据...

    乐观锁测试代码

    1. **版本号机制**:每个记录都有一个版本号字段,每次更新时都会将版本号加一。当尝试更新时,如果读取到的版本号与数据库中的版本号不一致,就认为数据已被其他事务修改,更新操作失败。 2. **时间戳机制**:类似...

    java乐观锁

    常见的乐观锁实现方式有两种:版本号机制和CAS(Compare and Swap)算法。 1. 版本号机制:在数据表中增加一个版本字段,每次读取数据时都记录当前版本号,当更新数据时,会比较当前版本号与数据库中的版本号是否...

    面试必备之乐观锁与悲观锁

    乐观锁常见的实现方式有版本号机制和CAS(Compare And Swap)算法。乐观锁适用于读操作远多于写操作的场景,能够提高系统吞吐量。然而,如果冲突频繁,乐观锁可能导致大量重试,反而降低性能。 **版本号机制**: ...

    乐观锁的一种实现方式-CAS编程开发技术共4页.pdf

    CAS(Compare and Swap,比较并交换)是乐观锁的一种常见实现机制,尤其在多线程和并发编程中被广泛应用。它是一个原子操作,由硬件支持,可以无锁地完成对内存位置的更新。CAS包含三个参数:旧值、预期值和新值。当...

    Java并发篇乐观锁,悲观锁,自旋锁

    本文主要讨论了四种锁类型:乐观锁、悲观锁、自旋锁以及Java中的synchronized同步锁,并深入解析了synchronized锁的内部机制,包括其核心组件、实现方式以及锁的状态。 1. **乐观锁**:乐观锁假设在多线程环境下,...

    JAVA架构面试专题_面试必备之乐观锁与悲观锁.pdf

    乐观锁通常通过版本号机制或者CAS(Compare and Swap)算法实现。在Java中,`java.util.concurrent.atomic`包下的原子变量类如AtomicInteger、AtomicLong等,使用了CAS算法来实现乐观锁。 **版本号机制**是乐观锁的...

    面试必备之乐观锁与悲观锁.docx

    乐观锁有两种实现方式,一种是版本号机制,另一种是 CAS 算法。版本号机制是指在数据表中加上一个数据版本号字段,表示数据被修改的次数,当数据被修改时,version 值会加一。当线程 A 要更新数据值时,在读取数据的...

    CAS下ABA问题及优化方案

    例如,在库存扣减业务中,用户1和用户2同时执行库存扣减操作,虽然都通过了CAS乐观锁机制的检查,但是在执行修改操作时,可能会出现数据不一致的情况。 二、ABA问题出现原因 ABA问题的出现原因是CAS乐观锁机制中,...

    【面试资料】-(机构内训资料)面试必备之乐观锁与悲观锁.zip

    2. 掌握两种锁在实际数据库管理系统中的实现方式,如乐观锁的版本号机制和悲观锁的FOR UPDATE语句。 3. 分析各自适用的场景和优缺点,能根据业务需求选择合适的锁策略。 4. 能够解释在高并发环境下,如何利用这两种...

    面试必备之乐观锁与悲观锁.zip

    乐观锁通常通过版本号或时间戳实现,确保每次更新时都比较并更新这些版本信息。 悲观锁则采取较为保守的策略,认为并发环境中数据被修改的可能性较大,因此在读取数据时就会立即对其进行锁定,防止其他事务在此期间...

    p278 - p288 乐观锁和悲观锁

    乐观锁的实现通常是基于版本号或者时间戳的方式,通过比较版本号或者时间戳来确定数据是否被修改。 在选择锁的机制时,需要考虑的因素有很多,包括锁的开销、加锁失败后的处理方式、线程的切换成本等。选择合适的锁...

    面试官问:说说悲观锁、乐观锁、分布式锁?都在什么场景下使用?有什么技巧?.docx

    * 数据库的版本号也是一种乐观锁。 分布式锁(Distributed Lock) 分布式锁是一种特殊的锁机制,它可以在分布式系统中跨进程锁定资源。分布式锁可以使用 Redis、ZooKeeper 等分布式锁组件来实现。 使用场景: * ...

    并发编程下的锁机制,乐观锁、悲观锁、共享锁、排他锁、分布式锁、锁降级原理篇

    本文将详细讲解几种常见的锁机制:悲观锁、乐观锁、共享锁和排他锁,并简要介绍分布式锁以及锁降级原理。 1. **悲观锁**: 悲观锁是一种保守的策略,它假设在读取数据时,数据极有可能被其他线程修改。因此,悲观...

    锁机制学习与总结笔记参考

    常见的乐观锁实现有版本号机制和CAS操作。 六、锁的性能优化 1. 锁粗化:将多个连续的小粒度锁合并成一个大粒度锁,减少锁的开销。 2. 锁细化:将大粒度的锁拆分成更小的锁,减少锁保护的数据范围,增加并发性。 ...

    JAVA CAS实现原理与使用.docx

    Java并发编程中,CAS(Compare and Swap,比较并交换)是一种无锁算法,它提供了一种在多线程环境...因此,在实际使用中,开发者需要根据场景选择合适的同步策略,如使用带有版本号的乐观锁或适时切换到传统的锁机制。

Global site tag (gtag.js) - Google Analytics