当前位置: 首页 > article >正文

Java LinkedList 讲解

怀旧网个人博客网站地址:怀旧网,博客详情:Java LinkedList 讲解

LinkedList 简介

image-20240314102610501

特有方法

image-20240314102637373

主要作用就是用来操作双向链表的首位指针

源码分析

image-20240314103114607

  1. 可以看到LinkedList内部的属性就这么三个--第一个size是用来记录当前数据元素数量,然后frist和last就是分别用来记录头节点和尾节点的,并且数据类型都为Node类型

    image-20240314103258096

  2. Node 作为LinkedList的内部类,里面存储了当前元素的值item,和前驱节点prev和后继节点next连个指针

  3. 在想LinkedList中添加元素的时候默认调用

image-20240314103450883

  1. 代码作用创建一个新的节点,然后将新节点的前驱节点设置为当前的尾节点,后继节点设置为null,然后将当前的尾节点的后继节点设置为当前的新创建节点。然后将当前的新创建节的地址赋值给当前尾节点。但是如果当前的尾节点为空的时候,说明链表中一个元素都没有。然后就直接将心节点设置为头节点。最后让链表长度加1,并且操作次数在加1。完成默认的add添加元素方法。

  2. 然后其他的方法和我们正常的数据结构链表操作大致一样,参考双向链表:网页链接

特有方法测试

addFirst 方法

  • 就是直接创建一个新的节点然后让新节点的next指向原有的first位置,并将新的node的地址赋值给first头指针。
public static void main(String[] args){
    LinkedList<Integer> linkedList = new LinkedList<>();

    linkedList.addFirst(1);

    System.out.println(linkedList);
}

image-20240314104338518


addLase 方法

  • 同add方法一样可以参考add方法源码分析。(底层调用的方法都是同一个)
public static void main(String[] args){
    LinkedList<Integer> linkedList = new LinkedList<>();

    linkedList.addFirst(1);

    linkedList.addLast(2);

    System.out.println(linkedList);
}

image-20240314104656139


其他方法测试

public static void main(String[] args){
    LinkedList<Integer> linkedList = new LinkedList<>();

    linkedList.addFirst(1);

    linkedList.addLast(2);

    System.out.println(linkedList.getFirst());
    System.out.println(linkedList.getLast());

    linkedList.removeFirst();
    linkedList.removeLast();

    System.out.println(linkedList);
}

image-20240314104810255

注意事项

image-20240314104834598

image-20240314104840369

如果当前链表没有数据,执行删除同样会报错,以及get系列方法同样会报错-这边就不做演示了、

image-20240314104951970

image-20240314104956905


http://www.kler.cn/a/412043.html

相关文章:

  • day11_JS初识_语法
  • ArcGIS+deck.gl矢量切片三维化表示建筑白模
  • MySQL INSERT CRTATE DELETE DORP UPDATE WHERE 的用法
  • CANopen多电机控制的性能分析
  • 《基于FPGA的便携式PWM方波信号发生器》论文分析(三)——数码管稳定显示与系统调试
  • 高标准农田智慧农业系统建设方案
  • 数据结构(汇总)
  • 生成对抗网络(简要介绍)
  • Python从0到100(七十四):计算机视觉-距离变换算法的实战应用(文末送书)
  • 8款Pytest插件助力Python自动化测试
  • 【网络信息资源】HTML的使用
  • (五)Ubuntu22.04+Stable-Diffusion-webui AI绘画 模型转换插件安装及其使用
  • 【VUE3】VUE组合式(响应式)API常见语法
  • 光耦——光伏储能的隐形动力,引领绿色能源迈向新纪元
  • 论文阅读:A Software Platform for Manipulating theCamera Imaging Pipeline
  • unity | 动画模块之卡片堆叠切换
  • 34 基于单片机的指纹打卡系统
  • 林业产品推荐系统:Spring Boot技术内幕
  • java实现归并排序和快速排序
  • Linux操作系统2-进程控制3(进程替换,exec相关函数和系统调用)
  • 【Linux】/proc/sys/vm/drop_caches
  • 使用 Nginx 在 Ubuntu 22.04 上安装 LibreNMS 开源网络监控系统
  • i春秋-文件包含绕过(PHP伪协议的使用)
  • Altium Designer学习笔记 22-23 PCB快捷键设置_PCB模块化布局
  • JDBC 设置 PostgreSQL 查询中 any(?) 的参数
  • Vue 的 computed 如何实现接受一个参数