1、ArrayBlockingQueue采用动态数组
takeIndex和putIndex 表示存和取的两个数组下标。
有界 (必须指明数组大小)
不能存放null
读和写公用一个ReentrantLock
2、LinkedBlockingQueue采用链表实现
默认无界(可以在初始化时指明大小)
不能存放null
读和写有两把锁ReentrantLock takeLock和putLock
使用场景:
ArrayBlockingQueue预先分配好一段连续内存,更稳定
LinkedBlockingQueue 读写锁分离,吞吐量更大