【LinkedList】集合

1.1 LinkedList介绍

List是接口,有两个常用实现类

  • ArrayList

  • LinkedList


List有的特点,LinkedList,例如 也是允许有序 ,且可以重复

且大部分方法与ArrayList相似,都是可以通过下标来操作集合数据的

但是也特殊提了操作开头和结尾的方法,getFirst,getLast等方法


基于双向链表实现

1.2 演示API

复制代码
public class Demo2 {
​
    public static void main(String[] args) {
        // 创建对象
        LinkedList<Integer> list = new LinkedList<>( );
​
        // 添加元素
        list.add(3);
        list.add(3);
        list.add(1);
        list.add(4);
        list.add(2);
        System.out.println("list = " + list);
​
        // 在指定下标插入
        list.add(2,5);
        System.out.println("list = " + list);
​
        // E get(int i)
        Integer i = list.get(2);
        System.out.println("i = " + i);
​
        // 根据下标移除
        Integer old = list.remove(2);
        System.out.println("old = " + old);
        System.out.println("list = " + list);
​
        // 迭代
        for(int n:list){
            System.out.println(n );
        }
​
        // 相对arraylist有特殊方法,操作头和尾
        // 在开头添加
        list.addFirst(0);
        // 在结尾添加
        list.addLast(10);
        System.out.println("list = " + list);
​
        // list.removeFirst()
        // list.removeLast()
        // list.getFirst()
        // list.getLast()
​
    }
}

1.3 底层原理

LinkedList底层是通过双向链表实现的

双向链表在内存的特点

  • 链表中每个存储数据的叫做节点(node)

  • 每个节点(node)在空间上不是连续,但是节点内存储了上一个/下一个的位置信息

  • 也有下标,但是因为内存空间上不连续,所以无法通过下标直接定位的,

    • 通过下标找到元素,是判断下标位置,举例开头近,就从头遍历,依次找到它

    • 如果离尾近,从尾倒着遍历,依次找到它

    • 无论怎样,是无法直接定位,只能挨个查找

      复制代码
          Node<E> node(int index) {
              // assert isElementIndex(index);
              if (index < (size >> 1)) {
                  Node<E> x = first;
                  for (int i = 0; i < index; i++)
                      x = x.next;
                  return x;
              } else {
                  Node<E> x = last;
                  for (int i = size - 1; i > index; i--)
                      x = x.prev;
                  return x;
              }
          }
  • 这样解释了,LinkedList为什么提供了操作头xxFirst和尾xxxLast的方法

    • 因为直接操作头和尾不用遍历,直接取值
相关推荐
开开心心就好14 小时前
仅168KB的桌面图标自动隐藏工具
windows·计算机视觉·计算机外设·excel·启发式算法·宽度优先·csdn开发云
怪兽软家17 小时前
DaVinci Resolve/达芬奇 20安装教程及下载
windows·经验分享·生活
chao18984417 小时前
完整MES系统实现 (C# 客户端服务器)
服务器·windows·c#
Hello_Embed18 小时前
Windows 安装 Claude Code 并接入 模型
windows·笔记·ai编程
Muyuan199818 小时前
28.Paper RAG Agent 开发记录:修复 LLM Rerank 的解析、Fallback 与可验证性
linux·人工智能·windows·python·django·fastapi
AxureMost20 小时前
4DDiG DLL Fixe 1.0.8.2 系统DLL修复工具
windows
怣疯knight1 天前
Windows不安装 Android Studio如何打包安卓软件
android·windows·android studio
空中海1 天前
02. 静态逆向、Manifest 分析与 Smali 重打包
服务器·网络·windows
一拳一个娘娘腔1 天前
告别图形化界面:基于CLI的Windows系统入侵排查与防御实战手册
windows·安全
疋瓞1 天前
批处理_基础补充、文件和文件夹处理_02
windows