码迷,mamicode.com
首页 > 数据库 > 详细

ArrayBlockingQueue与LinkedBlockingQueue对比

时间:2020-04-30 23:09:56      阅读:85      评论:0      收藏:0      [点我收藏+]

标签:消费   max   插入   locking   val   多个   没有   直接   默认   

队列中锁的实现不同
ArrayBlockingQueue实现的队列中的锁是没有分离的,即生产和消费用的是同一个锁;
LinkedBlockingQueue实现的队列中的锁是分离的,即生产用的是putLock,消费是takeLock

因此,LinkedBlockingQueue的一大优点也是ArrayBlockingQueue所不具备的,就是在多个CPU的情况下,LinkedBlockingQueue可以做到同一时刻既消费、又生产。


在生产或消费时操作不同
ArrayBlockingQueue实现的队列中在生产和消费的时候,是直接将枚举对象插入或移除的;
LinkedBlockingQueue实现的队列中在生产和消费的时候,需要把枚举对象转换为Node进行插入或移除,会影响性能。


队列大小初始化方式不同
ArrayBlockingQueue实现的队列中必须指定队列的大小;
LinkedBlockingQueue实现的队列中可以不指定队列的大小,但是默认是Integer.MAX_VALUE*/,可以当做无界。

ArrayBlockingQueue与LinkedBlockingQueue对比

标签:消费   max   插入   locking   val   多个   没有   直接   默认   

原文地址:https://www.cnblogs.com/wl889490/p/12811416.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!