AQS源码解读(ReentrankLock的公平锁和非公平锁)
- 构建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 } - Debug所有断点处

- 流程图,个人理解,有些地方理解的不太透彻望包涵

AQS源码解读(ReentrankLock的公平锁和非公平锁)的更多相关文章
- AQS 源码解读之加锁篇
以 ReentrantLock 创建的非公平锁为基础,进行 AQS 全流程的分析. 分析 demo 一共有 A.B.C 三个线程. public class AQSDemo { // 带入一个银行办理 ...
- AbstractQueuedSynchronizer 源码解读(转载)
转载文章,拜读了一下原文感觉很不错,转载一下,侵删 链接地址:http://objcoding.com/2019/05/05/aqs-exclusive-lock/ Java并发之AQS源码分析(一) ...
- java架构之路(多线程)AQS之ReetrantLock显示锁的使用和底层源码解读
说完了我们的synchronized,这次我们来说说我们的显示锁ReetrantLock. 上期回顾: 上次博客我们主要说了锁的分类,synchronized的使用,和synchronized隐式锁的 ...
- 死磕 java同步系列之ReentrantLock源码解析(一)——公平锁、非公平锁
问题 (1)重入锁是什么? (2)ReentrantLock如何实现重入锁? (3)ReentrantLock为什么默认是非公平模式? (4)ReentrantLock除了可重入还有哪些特性? 简介 ...
- AQS源码详细解读
AQS源码详细解读 目录 AQS源码详细解读 基础 CAS相关知识 通过标识位进行线程挂起的并发编程范式 MPSC队列的实现技巧 代码讲解 独占模式 独占模式下请求资源 独占模式下的释放资源 共享模式 ...
- AQS源码深入分析之独占模式-ReentrantLock锁特性详解
本文基于JDK-8u261源码分析 相信大部分人知道AQS是因为ReentrantLock,ReentrantLock的底层是使用AQS来实现的.还有一部分人知道共享锁(Semaphore/Count ...
- AQS源码探究之竞争锁资源
AQS源码探究---竞争锁资源 我们进入ReentrantLock源码中查看其内部类 Sync 对AQS进行扩展公共方法并定义抽象方法的抽象类 FaireSync 实现公平锁的AQS的实现类 UnFa ...
- JUC锁:核心类AQS源码详解
目录 1 疑点todo和解疑 2 AbstractQueuedSynchronizer学习总结 2.1 AQS要点总结 2.2 细节分析 2.2.1 插入节点时先更新prev再更新前驱next 2.2 ...
- 硬核剖析Java锁底层AQS源码,深入理解底层架构设计
我们常见的并发锁ReentrantLock.CountDownLatch.Semaphore.CyclicBarrier都是基于AQS实现的,所以说不懂AQS实现原理的,就不能说了解Java锁. 上篇 ...
随机推荐
- zjnu1749 PAROVI (数位dp)
Description The distance between two integers is defined as the sum of the absolute result of subtra ...
- Codeforces Round #686 (Div. 3) E. Number of Simple Paths (思维,图,bfs)
题意:有一个\(n\)个点,\(n\)条边的图,问你长度至少为\(1\)的简单路径有多少条. 题解:根据树的性质,我们知道这颗树一定存在一个环,假如一棵树没有环,那么它的所有长度不小于\(1\)的简单 ...
- hdu 4315 Climbing the Hill && poj 1704 Georgia and Bob阶梯博弈--尼姆博弈
参考博客 先讲一下Georgia and Bob: 题意: 给你一排球的位置(全部在x轴上操作),你要把他们都移动到0位置,每次至少走一步且不能超过他前面(下标小)的那个球,谁不能操作谁就输了 题解: ...
- hdu4528 小明系列故事——捉迷藏
Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total Submission(s ...
- linux 部署 .net core mvc
1.本地编写一个mvc网站 代码编辑器:Visual studio 2017.2019.Visual Code 均可 1)搭建 略. (请自行搜索如何编辑mvc,或看文末参考链接) 2)配置 Prog ...
- SPU与SKU概念
1. 什么是SPU SPU 是商品信息聚合的最小单位,是一组可复用.易检索的标准化信息的集合,该集合描述了一个产品的特性.即:某一款商铺的公共属性. 通俗点讲,属性值.特性相同的货品就可以称为一个 S ...
- 国产网络损伤仪SandStorm -- 为什么数据流还是走Bypass链路?
如果你在使用网络损伤仪SandStorm测试移动互联网的应用程序或者在仿真所谓"弱网测试"的时候,发现所有的数据流还是在走Bypass链路,并没有预期地走自己创建的仿真链路,那么你 ...
- C - C工程编译那些事【configure-make || cmake-make】
一.cofigure是怎么生成的,我们又是怎么使用的 configure和make install背后的故事: https://azyet.github.io/2015/06/20/configure ...
- docker的底层-隔离的核心
在了解底层原理之前: 说几个名词: 解耦状态: 所有东西都没有重复,任何东西都没有公用的地方. 半解耦状态:有部分共同的一起用,其他的独立 完全解耦状态: 就是各自都是独立没有重复. kvm:完全解耦 ...
- codeforces 11B Jumping Jack
Jack is working on his jumping skills recently. Currently he's located at point zero of the number l ...