ArrayBlockingQueue与LinkedBlockingQueue区别

1、ArrayBlockingQueue采用动态数组

      takeIndex和putIndex 表示存和取的两个数组下标。

      有界 (必须指明数组大小)

      不能存放null

      读和写公用一个ReentrantLock

2、LinkedBlockingQueue采用链表实现

     默认无界(可以在初始化时指明大小)

    不能存放null

    读和写有两把锁ReentrantLock takeLock和putLock

使用场景:

ArrayBlockingQueue预先分配好一段连续内存,更稳定

LinkedBlockingQueue 读写锁分离,吞吐量更大

    

猜你喜欢

转载自www.cnblogs.com/yangfei629/p/11567791.html