ArrayBlockingQueue与LinkedBlockingQueue区别


1、ArrayBlockingQueue采用动态数组

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

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

      不能存放null

      读和写公用一个ReentrantLock

 

2、LinkedBlockingQueue采用链表实现

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

    不能存放null

    读和写有两把锁ReentrantLock takeLock和putLock

 

使用场景:

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

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

    


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM