java.util.concurrent包下面的工具类实现同步的方式都是基于AQS

  1. AQS : AbstractQueuedSynchronizer  队列同步器,内部的队列是一个虚拟的队列,主要是用 Node 的一个双向列表

  2. CAS:compareAndSet  JDK乐观锁的实现方式 ,底层是用

    return unsafe.compareAndSwapInt(this, stateOffset, expect, update);   java的计算机本地方法实现的

  3. ReentrantLock 封装的加锁和释放锁的方法都是都委托给一个叫Sync的类来实现的

  4. sync : 是AbstractQueuedSynchronizer的子类,主要分为  公平锁 FairSync 和 非公平锁 NonfairSync

  5. sync 主要是用compareAndSetState方法(CAS方式)获取乐观锁的 ,获取不到就加入等待队列


转载于:https://my.oschina.net/st9/blog/670939

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值