作者简介:大家好,我是码炫码哥,前中兴通讯、美团架构师,现任某互联网公司CTO,兼职码炫课堂主讲源码系列专题
代表作:《jdk源码&多线程&高并发》,《深入tomcat源码解析》,《深入netty源码解析》,《深入dubbo源码解析》,《深入springboot源码解析》,《深入spring源码解析》,《深入redis源码解析》等
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬。码炫课堂的个人空间-码炫码哥个人主页-面试,源码等
LinkedBlockingQueue是大小不定的BlockingQueue,若其构造函数带一个规定大小的参数,生成的BlockingQueue有大小限制,若不带大小参数,所生成的BlockingQueue的大小由Integer.MAX_VALUE来决定.其所含的对象是以FIFO(先入先出)顺序排序的。
1、LinkedBlockingQueue的继承体系结构
public class LinkedBlockingQueue<E> extends AbstractQueue<E>
implements BlockingQueue<E>, java.io.Serializable
LinkedBlockingQueue的继承体系结构如下,和ArrayBlockingQueue一模一样。
2、LinkedBlockingQueue的相关属性介绍
1、链表节点
static class Node<E> {
E item;
Node<E> next;
Node(E x) { item = x; }
}
2、private final int capacity;容量边界,如果没有指定,则为Integer.MAX_VALUE
3、private final AtomicInteger count = new AtomicInteger(); 当前队列中存储元素的数量
4、transient Node head;队列的头结点,且始终head.item=null,