Java小白入门教程:LinkedList

目录

一、定义

二、作用

1、存储数据

2、动态扩容

3、提供方便的操作方法

三、使用场景

1.当你需要频繁地在列表的开头或结尾添加或删除元素时。

2.当你不需要按索引快速访问元素时,因为LinkedList访问元素需要从头开始遍历

3.当你不需要线程安全的数据结构时。

四、语法及示例

1、创建LinkedList

2、添加元素

3、获取元素

4、修改元素

5、删除元素

6、获取/计算大小

7、遍历元素

8、判断是否包含某个元素

9、清空LinkedList

五、完整实例


一、定义

LinkedList是Java中的一个类,"它实现了List接口和Deque接口,可以用来存储一系列动态的、可重复的元素。

与ArrayList不同,LinkedList是基于链表实现的,每个元素(节点)包含数据和指向下一个节点的引用。

二、作用

1、存储数据

可以存储任意类型的对象,并且每个元素都有一个前驱和后继。

2、动态扩容

不需要预先指定大小,"它会根据需要自动增加或减少节点。

3、提供方便的操作方法

比如添加、删除、修改、查找等,特别是在列表的开头和结尾操作特别高效。

三、使用场景

1.当你需要频繁的在列表开头、中间、末尾等位置进行添加和删除元素操作。

2.当你不需要按索引快速访问元素时,因为LinkedList访问元素需要从头开始遍历

3.当你不需要线程安全的数据结构时。

四、语法及示例

1、创建LinkedList

除了String引用类型还有其他的基本数据类型对应的包装类(如下表)

【注意:LinkedList<E>,E只能是引用数据类型】

基本类型 引用类型
boolean Boolean
byte Byte
short Short
int Integer
long Long
float Float
double Double
char Character
java 复制代码
import java.util.LinkedList; // 引入LinkedList类

LinkedList<String> list = new LinkedList<String>(); // 创建一个字符串类型的LinkedList

2、添加元素

java 复制代码
list.add("苹果"); // 在末尾添加一个元素
list.addFirst("香蕉"); // 在开头添加一个元素
list.addLast("橘子"); // 在末尾添加一个元素,与add()方法相同

3、获取元素

java 复制代码
String firstFruit = list.getFirst(); // 获取第一个元素
String lastFruit = list.getLast(); // 获取最后一个元素
String fruit = list.get(1); // 获取索引为1的元素

4、修改元素

java 复制代码
list.set(0, "葡萄"); // 修改索引为0的元素

5、删除元素

java 复制代码
list.removeFirst(); // 删除第一个元素
list.removeLast(); // 删除最后一个元素
list.remove(1); // 删除索引为1的元素
list.remove("苹果"); // 删除第一个遇到的"苹果"元素

6、获取/计算大小

java 复制代码
int size = list.size(); // 获取LinkedList的大小

7、遍历元素

java 复制代码
for (String fruit : list) {
    System.out.println(fruit); // 逐个输出元素
}

8、判断是否包含某个元素

java 复制代码
boolean contains = list.contains("苹果"); // 判断是否包含"苹果"元素

9、清空LinkedList

java 复制代码
list.clear(); // 清空LinkedList中的所有元素

五、完整实例

java 复制代码
import java.util.LinkedList;

public class Tets {
    public static void main(String[] args) {
        LinkedList<String> fruits = new LinkedList<String>();

        // 添加元素
        fruits.add("苹果");
        fruits.addFirst("香蕉");
        fruits.addLast("橘子");

        // 输出所有元素
        System.out.println("水果列表:" + fruits);

        // 修改元素
        fruits.set(1, "葡萄");

        // 删除元素
        fruits.removeFirst();
        fruits.remove("橘子");

        // 遍历元素
        System.out.println("修改后的水果列表:");
        for (String fruit : fruits) {
            System.out.println(fruit);
        }

        // 获取大小
        System.out.println("水果列表大小:" + fruits.size());
    }
}
相关推荐
yyytucj1 分钟前
优化 PHP-FPM 参数配置:实现服务器性能提升
服务器·开发语言·php
鲤籽鲲6 分钟前
C# 中 [MethodImpl(MethodImplOptions.Synchronized)] 的使用详解
java·开发语言·c#
SomeB1oody14 分钟前
【Rust自学】19.5. 高级类型
开发语言·后端·设计模式·rust
逆风局?21 分钟前
Java基础——分层解耦——IOC和DI入门
java·开发语言
ybq1951334543140 分钟前
javaEE-8.JVM(八股文系列)
java·jvm·java-ee
通信.萌新1 小时前
【Qt】常用的容器
开发语言·qt
美味小鱼1 小时前
Rust枚举(Enum)完全指南:用类型安全表达多样性
开发语言·安全·rust
飞翔的佩奇1 小时前
Java项目: 基于SpringBoot+mybatis+maven+mysql实现的疾病防控综合管理系统(含源码+数据库+毕业论文)
java·数据库·spring boot·mysql·spring·毕业设计·疾病防控
power-辰南1 小时前
技术架构师成长路线(2025版)
java·架构师·学习路线·技术专家
二十雨辰1 小时前
[Java基础]面向对象
java·开发语言