- ArrayBlockingQueue
- 内部使用一个数组作为其存储空间,数组的存储空间是预先分配的。
- 优点:put和take操作不会增加GC的负担
- 缺点:put和take操作使用同一个锁,可能导致锁争用,导致较多的上下文切换
- 适合在生产者线程和消费者线程之间的并发程序较低的情况下使用
- LinkedBlockingQueue
- 内部存储空间是一个链表,而链表节点所需的存储空间是动态分配的
- 优点:put和take操作使用两个显示锁(putLock和takeLock)
- 缺点:增加了GC的负担
- 适合在生产者线程和消费者线程之间的并发程序较高的情况下使用
- SynchronousQueue
- 可以被看做一种特殊的有界队列
- 生产者线程生产一个产品之后,会等待消费者线程来取走这个产品,才会接着生产下一个产品
- 适合在生产者线程和消费者线程之间的处理能力相差不大的情况下使用