JDK源码JDK的java.util.concurrent包结构

Posted KeepGoing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JDK源码JDK的java.util.concurrent包结构相关的知识,希望对你有一定的参考价值。

本文从JDK源码包中截取出concurrent包的所有类,对该包整体结构进行一个概述。
JDK1.5之前,Java中要进行并发编程时,通常需要由程序员独立完成代码实现。当然也有一些开源的框架提供了这些功能,但是这些框架依然没有JDK自带的功能使用起来方便。

而当针对高质量Java多线程并发程序设计时,比如使用Java之前的wait()notify()synchronized等,需要考虑性能、死锁、公平性、资源管理以及如何避免线程安全性方面带来的危害等诸多因素,往往会采用一些较为复杂的安全策略,加重了程序员的开发负担。

万幸的是,在JDK1.5出现之后,Sun大神(Doug Lea)推出了java.util.concurrent工具包以简化并发完成。开发者们借助于此,将有效的减少竞争条件(race conditions)和死锁线程。concurrent包很好的解决了这些问题,为我们提供了更实用的并发程序模型。

JDKjava.util.concurrent包,包含两个子包atomiclocks

java.util.concurrent.atomic

atomic包含原子类。

java.util.concurrent.locks

locks包包含锁相关的类,如lock、condition等

java.util.concurrent

concurrent包下包含一些并发工具类,如Executors、Semaphore、CountDownLatch、CyclicBarrier、BlockingQueue等。

J.U.C的五大核心

上面是JDK源码中的concurrent包的结构,下面根据使用场景对J.U.C进行了分类。J.U.C核心由5大块组成:atomic包、locks包、collections包、tools包(AQS)、executor包(线程池)。
注意,此处的包是按使用逻辑分类的,不是实际的代码结构。

参考资料:
java的concurrent用法详解
java.util.concurrent包源码分析
阅读jdk源码
面试中并发类问题的准备和学习

以上是关于JDK源码JDK的java.util.concurrent包结构的主要内容,如果未能解决你的问题,请参考以下文章

关于JDK源码:我想聊聊如何更高效地阅读

JDK1.8源码下载及idea2021导入jdk1.8源码

JDK1.8源码下载及idea2021导入jdk1.8源码

idea 导入 jdk源码 解决compile code 后阅读jdk 源码

关于JDK源码:我想聊聊如何更高效地阅读.md

怎样读jdk源码