1.阻塞队列BlockingQueue
2.数组队列ArrayBlockingQueue
3.链表队列LinkedBlockingQueue
4.优先队列PriorityBlockingQueue
5.延时队列DelayQueue
6.同步队列SynchronousQueue
7.链表双向阻塞队列LinkedBlockingDeque
8.链表传输队列LinkedTransferQueue
9.同步计数器CountDownLatch
10.同步计数器 Semaphore
11.同步计数器CyclicBarrier
阻塞队列是一个支持两个附加操作的队列。获取和添加,常用于生产者消费者场景。
数组阻塞队列ArrayBlockingQueue 是一个数组支持的中阻塞队列,按照FIFO进行元素排序。生产者和消费者使用同一个锁进行加锁。大于阻塞队列容量会造成阻塞
链表阻塞队列LinkedBlockingQueue是基于链表的阻塞队列,内部维持一个缓冲队列,生产者和消费者用不同的锁进行加锁,生产者和消费者能够并行地操作队列中的数据,提高了整个队列的并发性能。大于阻塞队列容量会造成阻塞
优先级阻塞队列PriorityBlockingQueue:不阻塞生产者,没有消费数据时阻塞消费者,当生产者生产数据大于消费者消费数据时,时间长了会耗尽堆内存空间。采用公平锁。
延时队列DelayQueue 是一个支持延时获取元素的使用优先级队列的实现的无阻塞队列,队列必须实现Delayed和Comparable接口。
同步队列SynchronousQueue 是一个不存储元素的队列,每一个put必须等待一个take操作,否则不能添加元素。适合传递性场景。
链表传输队列LinkedTransferQueue 是一个链表结构组成的无界传输阻塞队列。
同步计数器CountDownLatch:是一个同步辅助类。一个或多个,等待另外N个线程完成某个事情之后才能执行。
同步计数器CyclicBarrier:N个线程相互等待,任何一个线程完成之前,所有线程都必须等待。