【Java】LinkedList增删机制和源码分析

LinkedList增删机制和源码分析

(1)LinkedList底层实现了双向链表和双端队列特点。两个属性first和last分别指向首结点和尾结点,每个结点(Node对象)里面又维护了pre、item、next三个属性,其中通过pre指向前一个,通过next指向后一个结点,最终实现双向链表。
在这里插入图片描述
(2)可以添加任意元素(元素可以重复),包括null。添加和删除不是通过数组完成的,相对来说效率较高。
(3)线程不安全,没有实现同步。

1、构造LinkedList,给linkedlist添加元素

import java.util.LinkedList;
@SuppressWarnings("all")
public class LinkedListSource {
    public static void main(String[] args) {
        LinkedList linkedList = new LinkedList();
        linkedList.add(1);
        linkedList.add(2);
        linkedList.add(3);
        System.out.println("====添加结点===");
        System.out.println("linkedList="+linkedList);
        linkedList.remove();
        System.out.println("====删除第一个结点===");
        System.out.println("linkedList="+linkedList);
    }
}

2、设置断点,debug增加结点机理

在这里插入图片描述

3、设置断点,debug删除第一个结点

在这里插入图片描述

4、代码运行结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值