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. POJ - 2406 Power Strings (后缀数组DC3版)

    题意:求最小循环节循环的次数. 题解:这个题其实可以直接用kmp去求最小循环节,然后在用总长度除以循环节.但是因为在练后缀数组,所以写的后缀数组版本.用倍增法会超时!!所以改用DC3法.对后缀数组还不 ...

  2. poj 2398Toy Storage

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3146   Accepted: 1798 Descr ...

  3. AtCoder Beginner Contest 177 D - Friends (并查集)

    题意:有\(n\)个人,给你\(m\)对朋友关系,朋友的朋友也是朋友,现在你想要将他们拆散放到不同的集合中,且每个集合中的人没有任何一对朋友关系,问最少需要多少集合. 题解:首先用并查集将朋友关系维护 ...

  4. Kibana 地标图可视化

    ElasticSearch 可以使用 ingest-geoip 插件可以在 Kibana 上对 IP 进行地理位置分析, 这个插件需要 Maxmind 的 GeoLite2 City,GeoLite2 ...

  5. Python 3的f-Strings:增强的字符串格式语法(指南)

    最近也在一个视频网站的爬虫,项目已经完成,中间有不少需要总结的经验. 从Python 3.6开始,f-Strings是格式化字符串的一种很棒的新方法.与其他格式化方式相比,它们不仅更具可读性,更简洁且 ...

  6. VScode 配置c++环境

    参考 https://code.visualstudio.com/docs/cpp/config-mingw https://zhuanlan.zhihu.com/p/77645306 主要 http ...

  7. IFIX 5.9 历史数据 曲线 (非SQL模式)

    装完 ifix 5.9 默认是没有Hist 开头的 历史数据源的,没存,至少我装的版本是这样. 那个Historian 也没有安装包,好像还要授权,自己研究不了. 1 先把数据存本地 在你的安装包里 ...

  8. Caffe入门:对于抽象概念的图解分析

    Caffe的几个重要文件 用了这么久Caffe都没好好写过一篇新手入门的博客,最近应实验室小师妹要求,打算写一篇简单.快熟入门的科普文. 利用Caffe进行深度神经网络训练第一步需要搞懂几个重要文件: ...

  9. vue开发环境和生产环境配置

    开发环境配置 一般情况下开发环境是会跨域的,所以我们只需要在跨域的位置配置即可.进入config/index.js,在proxyTable对象里面添加代码,如下 '/api': { target: ' ...

  10. React Transforming Elements All In One

    React Transforming Elements All In One https://reactjs.org/docs/react-api.html#transforming-elements ...