【并发编程】【JDK源码】JDK的(J.U.C)java.util.concurrent包结构

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

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

万幸的是,在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源码
面试中并发类问题的准备和学习框架

相关文章
相关标签/搜索