Java List 集合详解:基础用法、常见实现类与高频面试题解析

正文

在 Java 集合框架中,List 是一个非常重要的接口,广泛用于存储有序的元素集合。本文将带你深入了解 List 接口的基本用法、常见实现类及其扩展,同时通过实际代码示例帮助你快速掌握这些知识。


👉点击获取2024Java学习资料

1. 什么是 List?

List 是 Java 集合框架中的一个接口,它继承了 Collection 接口,用于存储一组有序的元素。与普通数组相比,List 提供了动态调整大小和丰富操作方法的功能。

特点

  1. 元素有序,可通过索引访问。
  2. 允许存储重复的元素。
  3. 可以存储 null 值。

常用实现类

  • ArrayList
  • LinkedList
  • Vector
  • CopyOnWriteArrayList(线程安全)

2. List 的基本操作

以下是 List 接口的一些常用方法:

方法 描述
add(E e) 在列表末尾添加元素
add(int index, E e) 在指定位置插入元素
get(int index) 根据索引获取元素
set(int index, E e) 修改指定索引的元素
remove(int index) 移除指定索引的元素
size() 返回列表中元素的数量
contains(Object o) 判断列表是否包含指定元素
indexOf(Object o) 返回元素的首次出现索引
isEmpty() 判断列表是否为空

代码示例

```java
import java.util.*;

public class ListDemo {
    public static void main(String[] args) {
        List list = new ArrayList<>();
        // 添加元素
        list.add("Java");
        list.add("Python");
        list.add("C++");

        // 插入元素
        list.add(1, "JavaScript");

        // 获取元素
        System.out.println("元素:" + list.get(1));

        // 修改元素
        list.set(2, "C#");

        // 删除元素
        list.remove(3);

        // 遍历列表
        for (String item : list) {
            System.out.println(item);
        }
    }
}
```

3. 常用的 List 实现类

3.1 ArrayList

ArrayList 是基于动态数组实现的列表,适合频繁查询的场景。

特点

  • 随机访问效率高。
  • 插入或删除时可能需要移动大量元素。
  • 非线程安全。

代码示例

```java
import java.util.ArrayList;

public class ArrayListExample {
    public static void main(String[] args) {
        ArrayList numbers = new ArrayList<>();
        numbers.add(1);
        numbers.add(2);
        numbers.add(3);

        System.out.println("ArrayList: " + numbers);
    }
}
```

3.2 LinkedList

LinkedList 是基于双向链表实现的列表,适合频繁插入和删除的场景。

特点

  • 查询效率较低,需要从头开始遍历。
  • 插入和删除效率高。
  • 可以用作队列(Queue)或双端队列(Deque)。

代码示例

```java
import java.util.LinkedList;

public class LinkedListExample {
    public static void main(String[] args) {
        LinkedList queue = new LinkedList<>();
        queue.add("Alice");
        queue.add("Bob");
        queue.add("Charlie");

        System.out.println("LinkedList: " + queue);

        // 模拟队列操作
        System.out.println("Poll: " + queue.poll());  // 移除并返回队首元素
    }
}
```

3.3 Vector

Vector 是线程安全的动态数组,适合多线程场景。

特点

  • 每个方法都使用了同步机制。
  • 性能比 ArrayList 较低,但线程安全。

代码示例

```java
import java.util.Vector;

public class VectorExample {
    public static void main(String[] args) {
        Vector vector = new Vector<>();
        vector.add("Apple");
        vector.add("Banana");
        vector.add("Cherry");

        System.out.println("Vector: " + vector);
    }
}
```

3.4 CopyOnWriteArrayList

CopyOnWriteArrayList 是线程安全的 ArrayList 实现,适合多线程且读多写少的场景。

特点

  • 每次修改时都会复制底层数组。
  • 读操作不需要锁,性能高。
  • 写操作的性能较低。

代码示例

```java
import java.util.concurrent.CopyOnWriteArrayList;

public class CopyOnWriteArrayListExample {
    public static void main(String[] args) {
        CopyOnWriteArrayList list = new CopyOnWriteArrayList<>();
        list.add("Thread-safe");
        list.add("Example");

        System.out.println("CopyOnWriteArrayList: " + list);
    }
}
```

4. List 的扩展用法

4.1 排序操作

Collections.sort 方法可以对列表进行排序:

代码示例

```java
import java.util.*;

public class SortExample {
    public static void main(String[] args) {
        List numbers = Arrays.asList(5, 3, 8, 1);
        Collections.sort(numbers);
        System.out.println("排序后: " + numbers);
    }
}
```

4.2 遍历方式

  1. for-each 循环

    ```java
    

    for (String item : list) {
    System.out.println(item);
    }
    ```

  2. Iterator

    ```java
    

    Iterator iterator = list.iterator();
    while (iterator.hasNext()) {
    System.out.println(iterator.next());
    }
    ```

  3. Stream API

    ```java
    

    list.stream().forEach(System.out::println);
    ```

4.3 Stream 和 Lambda 表达式

利用 Stream 可以方便地对列表进行操作:

代码示例

```java
import java.util.*;

public class StreamExample {
    public static void main(String[] args) {
        List names = Arrays.asList("Alice", "Bob", "Charlie");
        names.stream()
             .filter(name -> name.startsWith("A"))
             .forEach(System.out::println);
    }
}
```

5. 面试中关于 List 的高频问题

  1. ArrayList 和 LinkedList 的区别

    • ArrayList 基于数组,查询快,插入和删除慢。
    • LinkedList 基于链表,插入和删除快,查询慢。
    • Vector 和 ArrayList 的区别

    • Vector 是线程安全的,ArrayList 是非线程安全的。

    • Vector 性能相对较低。
    • 线程安全的 List 实现有哪些?

    • Vector

    • CopyOnWriteArrayList
    • 如何避免 ConcurrentModificationException?

    • 使用 Iteratorremove 方法。

    • 使用线程安全的集合如 CopyOnWriteArrayList

6. 总结

List 是 Java 集合框架中非常重要的一部分,其各种实现类在不同的场景下各有优势。掌握 List 的基本用法和实现类的特性,不仅有助于日常开发,还能应对 Java 面试中的高频考察。

希望本文对你理解 List 及其常用扩展有所帮助!

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/5121.html

(0)
LomuLomu
上一篇 2025 年 1 月 1 日 上午5:31
下一篇 2025 年 1 月 1 日 上午6:04

相关推荐

  • Java通过百度地图API获取定位-普通IP定位

    登录邮箱提醒功能实现:基于IP定位的实践指南 在本项目中,我们旨在通过用户的IP地址获取其地理位置信息,以便在登录邮箱时提供更精确的提醒。以下是实现该功能的详细步骤和代码示例。 百度地图开放平台 本文将详细介绍如何利用百度地图开放平台的API来实现IP定位功能。首先,访问百度地图开放平台官网了解更多信息。 开始前的准备工作 在开始之前,我们需要完成以下步骤:…

    未分类 2024 年 12 月 27 日
    47800
  • manim边做边学–动画轨迹

    本篇介绍Manim中两个和动画轨迹相关的类,AnimatedBoundary和TracedPath。 AnimatedBoundary聚焦于图形边界的动态呈现,能精准控制边界绘制的每一帧,助力我们清晰展示几何图形的搭建流程。 TracedPath则擅长实时追踪物体或点的运动轨迹,以直观且动态的方式呈现各类运动路径,为我们分析和展示复杂运动提供了强大支持 。 …

    2025 年 1 月 6 日
    41900
  • 50个JAVA常见代码大全:学完这篇从Java小白到架构师

    50个JAVA常见代码大全:学完这篇从Java小白到架构师 Java,作为一门流行多年的编程语言,始终占据着软件开发领域的重要位置。无论是初学者还是经验丰富的程序员,掌握Java中常见的代码和概念都是至关重要的。本文将列出50个Java常用代码示例,并提供相应解释,助力你从Java小白成长为架构师。 基础语法 1. Hello World “`java p…

    未分类 2025 年 1 月 14 日
    46800
  • 双非二本,毕业一年多培训无果,拿到大厂 Offer

    大家好,我是R哥。 今天给大家分享一个逆袭的真实故事,本文的主人公小明(化名),小明是一名 2023 届往届生 ,毕业后因为种种原因,整整空档了一年多 。 小明的情况让我看了不禁感叹:“唉,这兄弟怎么搞啊的?这么年轻就躺平了? ”,毕竟,大家都知道,互联网行业的就业压力一年比一年大,稍微掉队,就可能被甩在后头,更别说还没就业就有这么长的空窗期。 然后,他选择…

    2025 年 1 月 15 日
    41000
  • 如何做好软件架构师

    本文以个人视野聊下软件架构师的工作以及软件架构设计知识。做开发工作接近10年了,期间主要做Windows应用开发。在成熟的“华南区最大WPF团队”希沃白板呆了较长一段时间、后面从0到1构建Windows技术栈以及会议屏软件集,在软件设计这块自己成长了很多。之前整理过如何做好技术经理 – 唐宋元明清2188 – 博客园,这里梳理下自己的设计思维,算是自己阶段性…

    未分类 2025 年 1 月 12 日
    33000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信