打算看一下concurrent包的源码,通过java并发编程的艺术这本书,大致将concurrent包分为五个模块
1. Aomic数据类型
这部分都被放在java.util.concurrent.atomic这个包里面,实现了原子化操作的数据类型,包括 Boolean, Integer, Long, 和Referrence这四种类型以及这四种类型的数组类型。
2. 锁
这部分都被放在java.util.concurrent.lock这个包里面,实现了并发操作中的几种类型的锁
3.ConcurrentHashMap实现
这部分实现的数据结构主要有List, Queue和Map。
4.多线程任务执行
这部分大体上涉及到三个概念,
Callable 被执行的任务
Executor 执行任务
Future 异步提交任务的返回数据
5. 线程管理类
这部分主要是对线程集合的管理的实现,有semaphore,CyclicBarrier, CountDownLatch,Exchanger等一些类