java collectionJava程序员

Java Collections Framework - Lin

2016-07-05  本文已影响2272人  美团Java

简书 占小狼
转载请注明原创出处,谢谢!

定义

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()能省掉指针的移动。

END。
我是占小狼。
在魔都艰苦奋斗,白天是上班族,晚上是知识服务工作者。
读完我的文章有收获,记得关注和点赞哦,如果非要打赏,我也是不会拒绝的啦!

上一篇下一篇

猜你喜欢

热点阅读