通常我们所说的并发包也就是java.util.concurrent,集中了Java并发的各种工具类。
同步结构:
CountDownLatch 允许一个或多个线程等待某些操作完成 CountDownLatch操作的是事件
CyclicBarrier 一种辅助性的同步结构,允许多个线程等待到大某个屏障 CyclicBarrier侧重点是线程
Semaphore Java版本的信号量实现
Phaser 功能与CountDownLatch很接近,允许线程动态的注册到Phaser上面,而CountDownLatch是不能动态设置的。
设计初衷是实现多个线程类似步骤、阶段场景的协调,线程注册等待屏障条件出发,进而协调彼此间的行动,具体参考这个例子。
线程安全的容器:
ConcurrentHashMap、侧重于Map放入或者获取的速度,而不在乎顺序
ConcurrentSkipListMap、在乎顺序,需要对数据进行非常频繁的修改
CopyOnWriteArrayList 任何修改操作,如add、set、remove,都会拷贝原数组,修改后替换原来的数组,通过这种防御性的方式,实现另类的线程安全。
CopyOnWriteArraySet
各种并发队列的实现:如各种BlockedQueue实现,比较典型的ArrayBlockingQueue、SynchorousQueue或针对特定场景的PriorityBlockingQueue等。
强大的Executor框架:可以创建各种不同类型的线程池,调度任务运行等,绝大部分情况下,不再需要自己从头实现线程池和任务调度器。
并发包里提供的线程安全Map、List和Set。参考下面类图
ConcurrentHashMap
ConcurrentSkipListMap
两个CopyOnWrite容器CopyOnWriteArrayList和CopyOnWriteArraySet