LinkedList的底层实现原理

一、LinkedList的特点

  • LinkedList底层实现了双向链表和双端队列特点可以添加任意元素(元素可以重复),包括null
  • 线程不安全,没有实现同步
    通过如下图可知
    在这里插入图片描述

二、LinkedList的底层实现

LinkedList中维护了4个属性:1、链表中节点的个数 .2、链表的头结点
3.链表的尾节点 4、对链表节点的修改次数

在这里插入图片描述

  • 而每个节点中都有item属性,用来存放数据的值
  • 每个节点中都有next属性,用来指向下一个节点
  • 每个节点中都有pre属性,用来指向上一个节点

有如下代码:

        List list=new LinkedList();
        list.add(1);
        list.add(2323);
        System.out.println(list);

如linkedList存放了两个元素:
在这里插入图片描述
**2.1首先进入无参构造,此时的各个成员初始值都为空
在这里插入图片描述
2.2如果是基本数据类型就进行自动装箱操作
在这里插入图片描述
2.3进入add()方法

2.4进入linkLadt(e)方法
在这里插入图片描述
2.5添加成功后,first和last都指向同一个节点在这里插入图片描述
2.6之后的每一次添加都在next的后面实现添加,而后一节点又可以指向上一节点,从而实现双向循环往复的指向

三、总结

比较下ArrayList和LinkedList的差别
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2年工作经验的小胡歌

你的打赏是对博主最大的支持和鼓

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值