1. 构建Debug代码:

     1 package com.hl.interview.lock;
    2
    3 import java.util.Scanner;
    4 import java.util.concurrent.locks.Lock;
    5 import java.util.concurrent.locks.LockSupport;
    6 import java.util.concurrent.locks.ReentrantLock;
    7
    8 /**
    9 * @author Hl
    10 * @create 2021/2/20 9:36
    11 */
    12 public class AQS {
    13 static Lock lock = new ReentrantLock();
    14 volatile static int flag = 0;
    15
    16 public static void main(String[] args) {
    17 Scanner scanner = new Scanner(System.in);
    18 Thread a = new Thread(() -> {
    19 lock.lock();
    20 try {
    21 System.out.println(Thread.currentThread().getName() + "先占用了");
    22 LockSupport.park();
    23 } finally {
    24 lock.unlock();
    25 }
    26 }, "A");
    27
    28 Thread b = new Thread(() -> {
    29 LockSupport.park();
    30 // 下面是断点处
    31 System.out.println("开始B线程");
    32 lock.lock();
    33 try {
    34 System.out.println(Thread.currentThread().getName() + "抢占");
    35 LockSupport.park();
    36 } finally {
    37 lock.unlock();
    38 }
    39 }, "B");
    40
    41 Thread c = new Thread(() -> {
    42 LockSupport.park();
    43 // 下面是断点处
    44 System.out.println("开始C线程");
    45 lock.lock();
    46 try {
    47 System.out.println(Thread.currentThread().getName() + "抢占");
    48 LockSupport.park();
    49 } finally {
    50 lock.unlock();
    51 }
    52 }, "C");
    53 a.start();
    54 b.start();
    55 c.start();
    56 System.out.print("请输入一个数:\t" );
    57 while (scanner.hasNextInt()) {
    58 System.out.print("请输入一个数:\t" );
    59 flag = scanner.nextInt();
    60 System.out.println();
    61 if (flag == 1) {
    62 System.out.println("释放了A线程");
    63 LockSupport.unpark(a);
    64 } else if (flag == 2) {
    65 System.out.println("释放了B线程");
    66 LockSupport.unpark(b);
    67 } else if (flag == 3) {
    68 System.out.println("释放了C线程");
    69 LockSupport.unpark(c);
    70 } else {
    71 System.out.println("退出了程序");
    72 break;
    73 }
    74 }
    75 }
    76 }
  2. Debug所有断点处
  3. 流程图,个人理解,有些地方理解的不太透彻望包涵

流程图地址

AQS源码解读(ReentrankLock的公平锁和非公平锁)的更多相关文章

  1. AQS 源码解读之加锁篇

    以 ReentrantLock 创建的非公平锁为基础,进行 AQS 全流程的分析. 分析 demo 一共有 A.B.C 三个线程. public class AQSDemo { // 带入一个银行办理 ...

  2. AbstractQueuedSynchronizer 源码解读(转载)

    转载文章,拜读了一下原文感觉很不错,转载一下,侵删 链接地址:http://objcoding.com/2019/05/05/aqs-exclusive-lock/ Java并发之AQS源码分析(一) ...

  3. java架构之路(多线程)AQS之ReetrantLock显示锁的使用和底层源码解读

    说完了我们的synchronized,这次我们来说说我们的显示锁ReetrantLock. 上期回顾: 上次博客我们主要说了锁的分类,synchronized的使用,和synchronized隐式锁的 ...

  4. 死磕 java同步系列之ReentrantLock源码解析(一)——公平锁、非公平锁

    问题 (1)重入锁是什么? (2)ReentrantLock如何实现重入锁? (3)ReentrantLock为什么默认是非公平模式? (4)ReentrantLock除了可重入还有哪些特性? 简介 ...

  5. AQS源码详细解读

    AQS源码详细解读 目录 AQS源码详细解读 基础 CAS相关知识 通过标识位进行线程挂起的并发编程范式 MPSC队列的实现技巧 代码讲解 独占模式 独占模式下请求资源 独占模式下的释放资源 共享模式 ...

  6. AQS源码深入分析之独占模式-ReentrantLock锁特性详解

    本文基于JDK-8u261源码分析 相信大部分人知道AQS是因为ReentrantLock,ReentrantLock的底层是使用AQS来实现的.还有一部分人知道共享锁(Semaphore/Count ...

  7. AQS源码探究之竞争锁资源

    AQS源码探究---竞争锁资源 我们进入ReentrantLock源码中查看其内部类 Sync 对AQS进行扩展公共方法并定义抽象方法的抽象类 FaireSync 实现公平锁的AQS的实现类 UnFa ...

  8. JUC锁:核心类AQS源码详解

    目录 1 疑点todo和解疑 2 AbstractQueuedSynchronizer学习总结 2.1 AQS要点总结 2.2 细节分析 2.2.1 插入节点时先更新prev再更新前驱next 2.2 ...

  9. 硬核剖析Java锁底层AQS源码,深入理解底层架构设计

    我们常见的并发锁ReentrantLock.CountDownLatch.Semaphore.CyclicBarrier都是基于AQS实现的,所以说不懂AQS实现原理的,就不能说了解Java锁. 上篇 ...

随机推荐

  1. hdu1541 Stars

    Problem Description Astronomers often examine star maps where stars are represented by points on a p ...

  2. 2015ACM/ICPC亚洲区沈阳站-重现赛 D - Pagodas

    题意:有\(n\)个数,开始给你两个数\(a\)和\(b\),每次找一个没出现过的数\(i\),要求满足\(i=j+k\)或\(i=j-k\),当某个人没有数可以选的时候判他输,问谁赢. 题解:对于\ ...

  3. C++ part7

    1.C++ 继承和组合 类的组合和继承一样,是复用的重要方式. 要优先使用组合而不是继承. 原因: 组合是黑箱复用,对局部类的内部细节不可见:继承是白箱复用,父类的内部细节可见,破坏封装性. 继承在编 ...

  4. SQL优化这么做就对了

    目录 前言 SQL优化一般步骤 1.通过慢查日志等定位那些执行效率较低的SQL语句 2.explain 分析SQL的执行计划 3.show profile 分析 4.trace 5.确定问题并采用相应 ...

  5. vue watch route params change

    vue watch route params change watch: { '$route.params.menuKey' (val, oldVal) { console.log('new rout ...

  6. uni-app 支持第三方 H5 离线包

    uni-app 支持第三方 H5 离线包 https://uniapp.dcloud.io/ https://github.com/dcloudio/uni-app refs xgqfrms 2012 ...

  7. short URL 短网址实现原理剖析

    short URL 短网址实现原理剖析 意义,简短便于分享,避免出现超长 URL 的字符长度限制问题 原理分析, 使用 HashMap 存储对应的映射关系 (长度不超过7的字符串,由大小写字母加数字共 ...

  8. How to change Linux Terminal display username

    How to change Linux Terminal display username 如何更改 Linux Terminal 显示的用户名 (base) ➜ ~ whoami xgqfrms-m ...

  9. Beacon API All In One

    Beacon API All In One Beacon API https://developer.mozilla.org/en-US/docs/Web/API/Beacon_API https:/ ...

  10. Suspense for Data Fetching

    Suspense for Data Fetching Experimental https://reactjs.org/docs/concurrent-mode-suspense.html React ...