首页  

ArrayBlockingQueue和LinkedBlockingQueue的区别     所属分类 java 浏览量 1328
1.    队列中锁的实现不同
       ArrayBlockingQueue实现的队列中的锁是没有分离的,即生产和消费用的是同一个锁;
       LinkedBlockingQueue实现的队列中的锁是分离的,即生产用的是putLock,消费是takeLock
    

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

3.    在生产或消费时操作不同
       ArrayBlockingQueue实现的队列中在生产和消费的时候,是直接将枚举对象插入或移除的;
       LinkedBlockingQueue实现的队列中在生产和消费的时候,需要把枚举对象转换为Node进行插入或移除,会影响性能
    
使用注意事项:
1.    LinkedBlockingQueue默认大小为Integer.MAX_VALUE ,生产速度大于消费速度时,可能会内存溢出
2.    使用ArrayBlockingQueue和LinkedBlockingQueue分别对100w个简单字符做入队操作,
       LinkedBlockingQueue的消耗时间是ArrayBlockingQueue的10倍左右

上一篇     下一篇
金庸武侠年表,终于把每部人物关系串起来了

20句超美古风句子

谷歌北京AI岗面试题

实用英语400句1

实用英语400句2

实用英语400句3