public E removeLast() {
final Node<E> l = last;
if (l == null)
throw new NoSuchElementException();
return unlinkLast(l);
}
last ist eine Mitgliedsvariable. Warum nicht direkt in der Methode verwenden, anstatt sie einer endgültigen lokalen Variablen zuzuweisen?
看了下代码
last 是 transient 的吧
如果把他赋值给一个局部 final 变量就
不需要每次使用 last 都 check value 了吧
部分原因是这样做能保证线程安全。假设这个方法不用 l 变量而是直接引用 last 成员,那么判断就变成了
if(this.last == null)
。如果通过判断之后的瞬间,last 被赋值成了 null,那么下一句unlinkLast(this.last)
就会出现未知的结果。