LinkedList源码分析:双向循环链表实现

java以面向对象思想实现双向循环链表

public class LinkedList<E> {
	
    private transient Entry<E> header = new Entry<E>(null, null, null);
    private transient int size = 0;

    /**
     * 构造方法:初始化LinkedList时为header结点分配内存
     * 		并且使header结点的next、previous指向header结点
     */
    public LinkedList() {
        header.next = header.previous = header;
    }
    
    /**
     * LinkedList添加一个元素,默认的在链表最后一个位置添加
     * @param e
     * @return
     */
    public boolean add(E e) {
    	addBefore(e, header);
        return true;
    }
    
    /**
     * Inserts the specified element at the beginning of this list.
     *
     * @param e the element to add
     */
    public void addFirst(E e) {
    	addBefore(e, header.next);
    }

    /**
     * Appends the specified element to the end of this list.
     *
     * <p>This method is equivalent to {@link #add}.
     *
     * @param e the element to add
     */
    public void addLast(E e) {
    	addBefore(e, header);
    }
    /**
     * 以传递header.next为例,即在第一个位置添加元素
     * @param e
     * @param entry 即header.next,初始时header.next的地址即header的地址
     * @return
     */
    private Entry<E> addBefore(E e, Entry<E> entry) {
    	//	1、为结点分配内存,新结点的next、previous指向header结点
    	Entry<E> newEntry = new Entry<E>(e, entry, entry.previous);
    	//	2、newEntry.previous即header结点,使header结点的next指向newEntry
    	newEntry.previous.next = newEntry;
    	//	3、newEntry.previous即header结点, 使header结点的previous指向newEntry
    	newEntry.next.previous = newEntry;
    	size++;
    	return newEntry;
    }
    
    private static class Entry<E> {
		E element;
    	Entry<E> next;
    	Entry<E> previous;

    	Entry(E element, Entry<E> next, Entry<E> previous) {
    	    this.element = element;
    	    this.next = next;
    	    this.previous = previous;
    	}
     }
}

note :LinkedList的对象始终存在一个数据为NULL的header结点

添加第一个元素的过程如图所示:过程1、2、3  在代码中指出。添加第二个元素在此基础上执行1、2、3过程。

初次分享,其中错误之处多多指出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值