ArrayBlockingQueue与LinkedBlockingQueue区别

1、ArrayBlockingQueue采用动态数组

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

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

      不能存放null

      读和写公用一个ReentrantLock

 

2、LinkedBlockingQueue采用链表实现

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

    不能存放null

    读和写有两把锁ReentrantLock takeLock和putLock

 

使用场景:

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

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

    

posted @ 2019-09-22 15:54  蓝天随笔  阅读(1563)  评论(0编辑  收藏  举报