代码改变世界

【转载】Java Collections Framework - LinkedList

2017-12-10 15:52  逍楚客  阅读(102)  评论(0)    收藏  举报

原文链接:

定义

package java.util;public class LinkedList<E> extends AbstractSequentialList<E>
 implements List<E>, Deque<E>, Cloneable, java.io.Serializable { 
    transient int size = 0; 
    transient Node<E> first; 
    transient Node<E> last;
}

概述

LinkedList以双向链表实现,允许重复。(如下Node的实现)并保留头指针和尾指针。

private static class Node<E> {
    E item; Node<E> next;
    Node<E> prev; 
    Node(Node<E> prev, E element, Node<E> next) { 
        this.item = element; 
        this.next = next; 
        this.prev = prev; 
    } 
}

链表无容量限制,但双向链表本身使用了更多空间,也需要额外的链表指针操作。   
按下标访问元素—get(i)/set(i,e) 要悲剧的遍历链表将指针移动到位(如果i>数组大小的一半,会从末尾移起)。
插入、删除元素时修改前后节点的指针即可,但还是要遍历部分链表的指针才能移动到下标所指的位置,只有在链表两头的操作—add(), addFirst(),removeLast()或用iterator()上的remove()能省掉指针的移动。



作者:占小狼
链接:http://www.jianshu.com/p/ebc61ab99fd6
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。