为什么 Java 的 LinkedList 的双链表实现不会链接后面元素
JDK7中
LinkedList
private 方法private void linkFirst(E e)
在新添加元素时链表不会断裂?
代码来源于 JDK7
private void linkFirst(E e) {
final Node<E> f = first;
final Node<E> newNode = new Node<>(null, e, f);
first = newNode;
if (f == null)
last = newNode;
else
f.prev = newNode;
// 此处没有执行 newNode.next = f; newNode.next 不会链接后面的元素
size++;
modCount++;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
为什么会断链呢?
f指向原来的first,将新的newNode设置为first。
这个时候就判断,如果原来的链表就是空的,那么last也就是first咯。
如果不为空,那么就是将f<原来的首节点>的prev就指向first。
我猜你之所以觉得会断链是因为,你没看到first的next指向f。额next这个在Node中已经传进去了
final Node<E> newNode = new Node<>(null, e, f);
private static class Node<E> {