Java小白入门教程:LinkedList

news/2025/2/3 2:17:12 标签: java, 开发语言

目录

一、定义

二、作用

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只能是引用数据类型】

基本类型引用类型
booleanBoolean
byteByte
shortShort
intInteger
longLong
floatFloat
doubleDouble
charCharacter
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());
    }
}


http://www.niftyadmin.cn/n/5840427.html

相关文章

Games104——引擎工具链高级概念与应用

世界编辑器 其实是一个平台&#xff08;hub&#xff09;&#xff0c;集合了所有能够制作地形世界的逻辑 editor viewport&#xff1a;可以说是游戏引擎的特殊视角&#xff0c;会有部分editor only的代码&#xff08;不小心开放就会变成外挂入口&#xff09;Editable Object&…

如何选择Spring AOP的动态代理?JDK与CGLIB的适用场景

Spring AOP在默认情况下使用的动态代理方式&#xff0c;可以比作是餐厅里的“智能服务员助手”。 Spring AOP默认提供了两种动态代理方式&#xff1a;JDK动态代理和CGLIB代理。其选择取决于被代理的对象是否实现了接口&#xff0c;以及配置的代理模式。默认情况下&#xff0c;…

2.攻防世界PHP2及知识点

进入题目页面如下 意思是你能访问这个网站吗&#xff1f; ctrlu、F12查看源码&#xff0c;什么都没有发现 用kali中的dirsearch扫描根目录 命令如下&#xff0c;根据题目提示以及需要查看源码&#xff0c;扫描以php、phps、html为后缀的文件 dirsearch -u http://61.147.17…

C#属性和字段(访问修饰符)

不同点逻辑性/灵活性存储性访问性使用范围安全性属性(Property)源于字段,对字段的扩展,逻辑字段并不占用实际的内存可以被其他类访问对接收的数据范围做限定,外部使用增加了数据的安全性字段(Field)不经过逻辑处理占用内存的空间及位置大部分字段不能直接被访问内存使用不安全 …

C++ strcpy和strcat讲解

目录 一. strcpy 代码演示&#xff1a; 二.strcat 代码演示&#xff1a; 一. strcpy 使⽤字符数组可以存放字符串&#xff0c;但是字符数组能否直接赋值呢&#xff1f; ⽐如&#xff1a; char arr1[] "abcdef"; char arr2[20] {0}; arr2 arr1;//这样这节赋值可…

89,[5]攻防世界 web Web_php_include

进入靶场 <?php // 显示当前 PHP 文件的源代码&#xff0c;方便调试或展示代码内容 show_source(__FILE__);// 从 URL 的查询字符串中获取名为 hello 的参数值&#xff0c;并将其输出到页面上 // 例如&#xff0c;当访问的 URL 为 "example.php?helloworld" 时&…

MATLAB中savefig函数用法

目录 语法 说明 示例 将当前图窗保存到 FIG 文件 将多个图窗保存到 FIG 文件 使用 compact 选项保存图窗 savefig函数的功能是将图窗和内容保存到 FIG 文件。 语法 savefig(filename) savefig(H,filename) savefig(H,filename,compact) 说明 savefig(filename) 将当前…

Unity3D仿星露谷物语开发26之创建场景控制管理器

1、目标 创建场景控制管理器&#xff0c;来加载和卸载场景&#xff0c;以实现场景之间的切换。 2、思路 Fade To Back是黑色的过渡场景&#xff0c;透明度逐渐变为1。 Fade To Transparent To Show Scene&#xff1a;黑色消失的过渡场景&#xff0c;透明度逐渐变为0. 事件触发…