随笔分类 -  JDK 源码笔记

个人 JDK 源码学习笔记
摘要:前面在学习 JUC 源码时,很多代码举例中都使用了线程池 ThreadPoolExecutor ,并且在工作中也经常用到线程池,所以现在就一步一步看看,线程池的源码,了解其背后的核心原理。 阅读全文
posted @ 2020-11-16 10:40 程序员小航 阅读(375) 评论(0) 推荐(1) 编辑
摘要:JUC 下面还有一个系列的类,都是 CopyOnWriteXXX ,意思是写时复制,这个究竟是怎么回事?那就以 CopyOnWriteArrayList 为切入点,一起了解写时复制是怎么回事? 阅读全文
posted @ 2020-11-08 22:31 程序员小航 阅读(64) 评论(0) 推荐(0) 编辑
摘要:JUC 下面的相关源码继续往下阅读,这就看到了非阻塞的无界线程安全队列 —— ConcurrentLinkedQueue,来一起看看吧。 阅读全文
posted @ 2020-11-08 22:27 程序员小航 阅读(168) 评论(0) 推荐(0) 编辑
摘要:上一节看了基于数据的有界阻塞队列 ArrayBlockingQueue 的源码,通过阅读源码了解到在 ArrayBlockingQueue 中入队列和出队列操作都是用了 ReentrantLock 来保证线程安全。下面咱们看另一种有界阻塞队列:LinkedBlockingQueue。 阅读全文
posted @ 2020-11-08 22:14 程序员小航 阅读(82) 评论(0) 推荐(0) 编辑
摘要:在介绍 AQS 时,其中有一个内部类叫做 ConditionObject,当时并没有进行介绍,并且在后续阅读源码时,会发现很多地方用到了 Condition ,这时就会很诧异,这个 Condition 到底有什么作用?那今天就通过阅读 Condition 源码,从而弄清楚 Condition 到底是做什么的?当然阅读这篇文章的时候希望你已经阅读了 AQS、ReentrantLock 以及 LockSupport 的相关文章或者有一定的了解(~~当然小伙伴也可以直接跳到文末看总结~~)。 阅读全文
posted @ 2020-11-08 22:10 程序员小航 阅读(240) 评论(0) 推荐(0) 编辑
摘要:在 JUC 中线程同步器除了 CountDownLatch 和 CycleBarrier ,还有一个叫做 Semaphore (信号量),同样是基于 AQS 实现的。下面来看看信号量的内部原理。 阅读全文
posted @ 2020-11-08 22:08 程序员小航 阅读(265) 评论(0) 推荐(0) 编辑
摘要:看完 CountDownLatch 正准备表示一番,突然看到了一个 CyclicBarrier —— 回环屏障。沃特?回环还屏障?说比 CountDownLatch 要多一个回环,那咱可得瞧一瞧,看一看了! 阅读全文
posted @ 2020-11-08 17:52 程序员小航 阅读(83) 评论(0) 推荐(0) 编辑
摘要:CountDownLatch 一个同步辅助工具,同样是基于 AQS 实现,本篇文件主要是介绍 CountDownLatch 的使用,以及源码。 阅读全文
posted @ 2020-11-08 17:50 程序员小航 阅读(101) 评论(0) 推荐(0) 编辑
摘要:在了解完 ReentrantLock 和 ReentrantReadWriteLock 之后,惊奇的发现 JUC 下还有一个 StampedLock 。 查阅资料发现是 JDK8 新增的一个锁。现在已经 JDK15 了,原谅我的孤陋寡闻,实在是业务开发中用的太少。那行吧,赶紧来看一下 StampedLock 到底是什么?为什么有了 ReentrantLock 和 ReentrantReadWriteLock 之后还要设计一个 StampedLock ? 阅读全文
posted @ 2020-11-07 10:39 程序员小航 阅读(113) 评论(0) 推荐(0) 编辑
摘要:在看完 ReentrantLock 之后,在高并发场景下 ReentrantLock 已经足够使用,但是因为 ReentrantLock 是独占锁,同时只有一个线程可以获取该锁,而很多应用场景都是读多写少,这时候使用 ReentrantLock 就不太合适了。读多写少的场景该如何使用?在 JUC 包下同样提供了读写锁 ReentrantReadWriteLock 来应对读多写少的场景。 阅读全文
posted @ 2020-11-07 10:28 程序员小航 阅读(285) 评论(0) 推荐(0) 编辑
摘要:在阅读完 JUC 包下的 AQS 源码之后,其中有很多疑问,最大的疑问就是 state 究竟是什么含义?并且 AQS 主要定义了队列的出入,但是获取资源、释放资源都是交给子类实现的,那子类是怎么实现的呢?下面开始了解 ReentrantLock。 阅读全文
posted @ 2020-11-05 22:37 程序员小航 阅读(177) 评论(0) 推荐(0) 编辑
摘要:AbstractQueuedSynchronizer 抽象队列同步器,简称 AQS 。是在 JUC 包下面一个非常重要的基础组件,JUC 包下面的并发锁 `ReentrantLock` `CountDownLatch` 等都是基于 AQS 实现的。所以想进一步研究锁的底层原理,非常有必要先了解 AQS 的原理。 阅读全文
posted @ 2020-11-05 22:24 程序员小航 阅读(177) 评论(0) 推荐(0) 编辑
摘要:LockSupport 是 JUC 中常用的一个工具类,主要作用是挂起和唤醒线程。在阅读 JUC 源码中经常看到,所以很有必要了解一下。 阅读全文
posted @ 2020-11-05 21:07 程序员小航 阅读(103) 评论(0) 推荐(0) 编辑
摘要:在介绍 AtomicInteger 时,已经说明在高并发下大量线程去竞争更新同一个原子变量时,因为只有一个线程能够更新成功,其他的线程在竞争失败后,只能一直循环,不断的进行 CAS 尝试,从而浪费了 CPU 资源。而在 JDK 8 中新增了 LongAdder 用来解决高并发下变量的原子操作。下面同样通过阅读源码来了解 LongAdder 。 阅读全文
posted @ 2020-11-05 10:06 程序员小航 阅读(146) 评论(0) 推荐(0) 编辑
摘要:业务开发中经常使用 ThreadLocal 来存储用户信息等线程私有对象... ThreadLocal 内部构造是什么样子的?为什么可以线程私有?常说的内存泄露又是怎么回事? 阅读全文
posted @ 2020-11-05 00:30 程序员小航 阅读(570) 评论(0) 推荐(0) 编辑
摘要:关于红黑树,在HashMap中是怎么应用的? 前言 在阅读HashMap源码时,会发现在HashMap中使用了红黑树,所以需要先了解什么是红黑树,以及其原理。从而再进一步阅读HashMap中的链表到红黑树的转换,红黑树的增删节点等。 什么是红黑树? 在HashMap中是怎么应用的? 什么是红黑树? 阅读全文
posted @ 2020-11-03 21:08 程序员小航 阅读(159) 评论(0) 推荐(0) 编辑
摘要:HashMap的put kv,是如何扩容的? 描述下HashMap put(k,v)的流程? 它的扩容流程是怎么样的? HashMap put(k,v)流程 通过hash(key方法)获取到key的hash值 调用put方法, 将value存放到指定的位置 根据hash值确定当前key所在node数 阅读全文
posted @ 2020-11-03 21:05 程序员小航 阅读(122) 评论(0) 推荐(0) 编辑
摘要:HashMap的初始化,到底都做了什么? HashMap初始化参数都是什么?默认是多少? 为什么建议初始化设置容量? tableSizeFor方法是做什么的? 如何获取到一个key的hash值?及计算下标? HashMap初始化参数都是什么?默认是多少? HashMap初始化参数分别是初始容量和负载 阅读全文
posted @ 2020-11-03 20:59 程序员小航 阅读(275) 评论(0) 推荐(0) 编辑
摘要:JUC 下面还有一个系列的类,都是 CopyOnWriteXXX ,意思是写时复制,这个究竟是怎么回事?那就以 CopyOnWriteArrayList 为切入点,一起了解写时复制是怎么回事? 阅读全文
posted @ 2020-11-03 14:23 程序员小航 阅读(133) 评论(0) 推荐(0) 编辑

点击右上角即可分享
微信分享提示
more_horiz
keyboard_arrow_up dark_mode palette
选择主题