本文从JDK
源码包中截取出concurrent
包的所有类,对该包整体结构进行一个概述。
在JDK1.5
之前,Java
中要进行并发编程时,通常需要由程序员独立完成代码实现。当然也有一些开源的框架提供了这些功能,但是这些框架依然没有JDK
自带的功能使用起来方便。
而当针对高质量Java
多线程并发程序设计时,比如使用Java
之前的wait()
、notify()
和synchronized
等,需要考虑性能、死锁、公平性、资源管理以及如何避免线程安全性方面带来的危害等诸多因素,往往会采用一些较为复杂的安全策略,加重了程序员的开发负担。
万幸的是,在JDK1.5
出现之后,Sun
大神(Doug Lea
)推出了java.util.concurrent
工具包以简化并发完成。开发者们借助于此,将有效的减少竞争条件(race conditions
)和死锁线程。concurrent
包很好的解决了这些问题,为我们提供了更实用的并发程序模型。
JDK
的java.util.concurrent
包,包含两个子包atomic
和locks
。
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源码
面试中并发类问题的准备和学习