一、简介
二、分析
2.1 类结构
2.1.0 类结构图
2.2 内部类
2.2.0 内部类列表图
2.2.1 Itr
2.2.2 Node
2.3 字段
2.3.0 字段列表图
2.3.1 array
-
/** * 内部维护的数组集合,只能通过getArray或setArray来访问 */ private transient volatile Object[] array;
2.3.2 lock
-
/** * 内部采用独占锁ReetrantLock来保证并发操作 */ final transient ReentrantLock lock = new ReentrantLock();
2.3.3 lockOffset
/**
* lock锁的在该类中的偏移量,方便Unsafe类进行cas操作
*/
private static final long lockOffset;
2.2.4 UNSAFE
/**
* 用来进行CAS操作的类
*/
private static final sun.misc.Unsafe UNSAFE;
2.4 代码块
2.4.1 静态代码块
/**
* 使用Unsafe的方法获取到头结点和尾结点字段的偏移量用于cas操作
*/
static {
try {
UNSAFE = sun.misc.Unsafe.getUnsafe();
Class k = ConcurrentLinkedQueue.class;
headOffset = UNSAFE.objectFieldOffset
(k.getDeclaredField("head"));
tailOffset = UNSAFE.objectFieldOffset
(k.getDeclaredField("tail"));
} catch (Exception e) {
throw new Error(e);
}
}
2.5 方法
2.5.0 方法列表图
2.5.1 构造函数