十分钟掌握Java集合之List接口

news2025/1/16 21:45:47

哈喽,各位小伙伴们,你们好呀,我是喵手。运营社区:C站/掘金/腾讯云;欢迎大家常来逛逛

  今天我要给大家分享一些自己日常学习到的一些知识点,并以文字的形式跟大家一起交流,互相学习,一个人虽可以走的更快,但一群人可以走的更远。

  我是一名后端开发爱好者,工作日常接触到最多的就是Java语言啦,所以我都尽量抽业余时间把自己所学到所会的,通过文章的形式进行输出,希望以这种方式帮助到更多的初学者或者想入门的小伙伴们,同时也能对自己的技术进行沉淀,加以复盘,查缺补漏。

小伙伴们在批阅的过程中,如果觉得文章不错,欢迎点赞、收藏、关注哦。三连即是对作者我写作道路上最好的鼓励与支持!

前言

  Java是一款面向对象的编程语言,也被称为“平台无关性”的语言。Java中的集合类是一种非常重要的数据结构,其中List接口类是最常用的一种。本篇文章将深入探讨Java中的List接口类,以帮助开发人员更好的理解和应用于实际开发中。

摘要

  本文将介绍Java中的List接口类,包括其定义、特点、应用场景、优缺点分析等内容。同时,还会通过源代码解析和测试用例,帮助读者更深入地了解List接口类的实现和使用方法。

List接口类

简介

  List是Java中的一个接口类,它扩展了Collection接口,并且可以按照索引位置存储和访问元素。List中的元素是按照插入顺序保存的,并且允许有重复元素存在。与数组不同的是,List的容量可以动态增长。

  List接口提供了一系列方法来对列表中的元素进行操作,包括添加、删除、获取、修改等。常用的List实现类有ArrayListLinkedList,它们在实现方式和性能方面具有不同的特点。

源代码解析

List接口类定义

public interface List<E> extends Collection<E> {
    int size();
    boolean isEmpty();
    boolean contains(Object o);
    Iterator<E> iterator();
    Object[] toArray();
    <T> T[] toArray(T[] a);
    boolean add(E e);
    boolean remove(Object o);
    boolean containsAll(Collection<?> c);
    boolean addAll(Collection<? extends E> c);
    boolean addAll(int index, Collection<? extends E> c);
    boolean removeAll(Collection<?> c);
    boolean retainAll(Collection<?> c);
    void clear();
    boolean equals(Object o);
    int hashCode();
    E get(int index);
    E set(int index, E element);
    void add(int index, E element);
    E remove(int index);
    int indexOf(Object o);
    int lastIndexOf(Object o);
    ListIterator<E> listIterator();
    ListIterator<E> listIterator(int index);
    List<E> subList(int fromIndex, int toIndex);
}

  上述代码为List接口类的定义,其中定义了大量的方法用于对列表中的元素进行操作。List接口类继承自Collection接口,并且扩展了一些额外的方法,如get()、set()、add()等。

  源码部分截图如下:

在这里插入图片描述

ArrayList实现类

  ArrayList是List接口的一个实现类,它是基于数组实现的。在创建ArrayList对象时,需要指定初始容量,如果不指定,则默认为10。当向ArrayList中添加元素时,如果当前容量不够,则会自动进行扩容。

public class ArrayList<E> extends AbstractList<E>
        implements List<E>, RandomAccess, Cloneable, java.io.Serializable {
    private static final long serialVersionUID = 8683452581122892189L;
    // Default initial capacity.
    private static final int DEFAULT_CAPACITY = 10;
    // Shared empty array instance used for empty instances.
    private static final Object[] EMPTY_ELEMENTDATA = {};
    // The array buffer into which the elements of the ArrayList are stored.
    transient Object[] elementData;
    // The size of the ArrayList (the number of elements it contains).
    private int size;
    // ...
}

  上述代码为ArrayList的部分实现,可以看到,ArrayList内部是通过一个Object数组来存储元素的,其中elementData表示存储元素的数组,size表示当前列表中元素的数量。

  源码部分截图如下:

在这里插入图片描述

LinkedList实现类

  LinkedList是List接口的另一个实现类,它是基于链表实现的。LinkedList内部维护了headtail两个指针,分别指向链表头和尾。

public class LinkedList<E>
    extends AbstractSequentialList<E>
    implements List<E>, Deque<E>, Cloneable, java.io.Serializable {
    transient int size = 0;
    transient Node<E> first;
    transient Node<E> last;
    // ...
    private static class Node<E> {
        E item;
        Node<E> next;
        Node<E> prev;
        Node(Node<E> prev, E element, Node<E> next) {
            this.item = element;
            this.next = next;
            this.prev = prev;
        }
    }
}

  上述代码为LinkedList的部分实现,可以看到,LinkedList内部是通过一个Node类来表示链表节点,其中prev表示前一个节点,next表示后一个节点。

  源码部分截图如下:

在这里插入图片描述

应用场景案例

  List接口类在实际开发中有广泛的应用场景,下面列举几个常见的应用案例:

数据存储

  List接口类是一个常见的数据结构,可以用于存储各种类型的数据,如整数、字符串、对象等。在实际开发中,我们经常需要将一些数据进行分组、排序或者过滤,这时List就成为了一个非常方便的数据结构。

集合运算

  List接口类支持一系列的集合运算,如交集、并集、差集等。这些运算可以帮助程序员快速地处理一些复杂的逻辑,如合并两个列表、查找两个列表中共有的元素等。

缓存实现

  List接口类可以作为缓存的数据结构,用于存储一些常用的数据。在程序中访问这些数据时,可以先从List中查找,如果没有命中,则再从数据库或者其他缓存中取出数据。这样可以提高程序的访问速度和效率。

优缺点分析

List接口类作为一个常见的数据结构,具有以下优点和缺点:

优点

  1. 支持按照索引位置存储和访问元素。

  2. 允许有重复元素存在。

  3. 内部实现可以选择数组或者链表,具有灵活性。

  4. 支持一系列的集合运算,方便程序员进行数据处理和操作。

缺点

  1. 添加和删除元素时,可能需要执行多次内存分配和拷贝操作,性能较差。

  2. 基于数组实现的List,在进行扩容时需要重新分配内存和拷贝数组,比较耗时。

类代码方法介绍

List接口类提供了一系列的方法用于对列表中的元素进行操作,下面列举一些常用的方法:

add(E e)

boolean add(E e);

该方法用于向列表末尾添加一个元素。

remove(Object o)

boolean remove(Object o);

该方法用于从列表中删除一个元素。

get(int index)

E get(int index);

该方法用于获取列表中指定索引位置的元素。

set(int index, E element)

E set(int index, E element);

该方法用于替换列表中指定索引位置的元素。

size()

int size();

该方法用于返回列表中元素的数量。

测试用例

下面给出一个简单的测试用例,以测试List接口类的基本功能:

测试代码

代码如下:

package com.example.javase.collection;

import java.util.ArrayList;
import java.util.List;

/**
 * @Author ms
 * @Date 2023-10-24 18:47
 */
public class ListTest {
    public static void main(String[] args) {
        List<String> list = new ArrayList<String>();
        list.add("A");
        list.add("B");
        list.add("C");
        System.out.println(list);
        list.remove("B");
        System.out.println(list);
        System.out.println(list.get(1));
        list.set(0, "D");
        System.out.println(list);
        System.out.println(list.size());
    }
}

  上述测试用例使用了ArrayList实现类,演示了一些基本操作,如添加元素、删除元素、获取元素、替换元素和获取列表长度等。

测试结果

根据如上测试用例,如下测试用例结果请参考:

在这里插入图片描述

测试代码分析

  在如上测试用例中,首先创建了一个ArrayList对象list,并向其中添加了三个元素"A"、“B”、“C”。接着,通过list.remove("B")方法,从列表中删除了元素"B"。

  然后,通过list.get(1)方法,获取了列表中索引为1的元素,即"C"。接着,通过list.set(0, "D")方法,将列表中索引为0的元素"A"替换为"D"。

  最后,通过list.size()方法,获取了列表的长度,即2。

全文小结

  本文介绍了Java中的List接口类,包括其定义、特点、应用场景、优缺点分析等内容。同时,还通过源代码解析和测试用例,帮助读者更深入地了解List接口类的实现和使用方法。

总结

  本文介绍了Java中的List接口类,包括其定义、特点、应用场景、优缺点分析等内容。同时,通过源代码解析和测试用例,帮助读者更深入地了解List接口类的实现和使用方法。List作为一种常见的数据结构,在实际开发中应用广泛,可以用于数据存储、集合运算、缓存实现等场景。尽管List具有许多优点,如支持按照索引存储和访问元素、允许有重复元素存在等,但也存在一些缺点,如添加和删除元素时性能较差、基于数组实现的List在进行扩容时需要重新分配内存和拷贝数组等。此外,本文还列举了一些List接口类的常用方法,如add、remove、get、set等,以及针对ArrayList实现类的测试用例,帮助读者更好地掌握List接口类的使用方法。

… …

文末

好啦,以上就是我这期的全部内容,如果有任何疑问,欢迎下方留言哦,咱们下期见。

… …

学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!

wished for you successed !!!


⭐️若喜欢我,就请关注我叭。

⭐️若对您有用,就请点赞叭。

⭐️若有疑问,就请评论留言告诉我叭。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1653647.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Day 28 MySQL的数据备份与恢复

数据备份及恢复 1.概述 ​ 所有备份数据都应放在非数据库本地&#xff0c;而且建议有多份副本 备份&#xff1a; 能够防止由于机械故障以及人为误操作带来的数据丢失&#xff0c;例如将数据库文件保存在了其它地方 冗余&#xff1a; 数据有多份冗余&#xff0c;但不等备份&…

GNU Radio FFT模块窗函数对比

文章目录 前言一、grc 图二、窗函数及对应的运行结果1、矩形窗2、汉明窗3、汉宁窗4、黑曼窗5、黑曼-哈里斯窗6、凯泽窗7、巴特利特窗8、平顶窗 前言 GNU Radio 中 FFT 模块的窗函数包括以下几种&#xff1a;矩形窗&#xff08;Rectangular Window&#xff09;、汉明窗&#xf…

分割模型Maskformer系列

maskformer&#xff1a;Per-Pixel Classification is Not All You Need for Semantic Segmentation 论文地址&#xff1a;https://arxiv.org/pdf/2107.06278 1.概述 传统的语义分割方法通常采用逐像素分类&#xff08;per-pixel classification&#xff09;&#xff0c;而实…

邦注科技 模具保护器 CCD电子眼 专业工业视觉检测设备

模具保护器是一种用于保护模具的设备&#xff0c;可以在塑料压铸和冲床等加工过程中起到保护模具的作用。以下是关于模具保护器在保护塑料压铸和冲床模具方面的应用&#xff1a; 塑料压铸模具保护器&#xff1a; 防止碰撞&#xff1a;在塑料压铸过程中&#xff0c;模具可能会…

【CSS基础--CSS选择器的常见用法】

CSS选择器的常见用法 1.CSS介绍1.1 基本语法规范1.2 引入样式1.3 规范 2. CSS选择器2.1 标签选择器2.2 类选择器2.3 ID选择器2.4 复合选择器 1.CSS介绍 CSS&#xff08;Cascading Style Sheet&#xff09;&#xff0c;层叠样式表&#xff0c;由于控制页面的样式。CSS能够对网页…

【已解决】‘pip‘ 不是内部或外部命令问题

&#x1f60e; 作者介绍&#xff1a;我是程序员行者孙&#xff0c;一个热爱分享技术的制能工人。计算机本硕&#xff0c;人工制能研究生。公众号&#xff1a;AI Sun&#xff0c;视频号&#xff1a;AI-行者Sun &#x1f388; 本文专栏&#xff1a;本文收录于《AI实战中的各种bug…

Linux网站服务

1.概念:HTML:超级文本编辑语言 网页:使用HTML,PHP,JAVA语言格式书写的文件。 主页:网页中呈现用户的第一个界面。 网站:多个网页组合而成的一台网站服务器。 URL:统一资源定位符&#xff0c;访问网站的地址。 网站架构:LAMP: LinuxApacheMYSQLPHP(系统服务器程序数据管理…

【JAVA语言-第20话】多线程详细解析(二)——线程安全,非线程安全的集合转换成线程安全

目录 线程安全 1.1 概述 1.2 案例分析 1.3 解决线程安全 1.3.1 synchronized关键字 1.3.1.1 同步代码块 1.3.1.2 同步方法 1.3.2 使用Lock锁 1.3.2.1 概述 代码示例 1.4 线程安全的类 1.4.1 非线程安全集合转换成线程安全集合 线程安全 1.1 概述 指如果有多…

外贸企业邮箱怎么注册?五款外贸企业邮箱注册步骤

专业的公司邮箱不但能提高企业形象&#xff0c;也能保证商业沟通的流畅与信息安全性。本文将详解五种常见的外贸企业邮箱——Zoho Mail公司邮箱、腾讯公司邮箱、阿里公司邮箱、网易公司邮箱以及Gmail公司邮箱的注册流程&#xff0c;协助外贸企业轻松完成邮箱注册&#xff0c;打…

安装Nox夜神模拟器关闭了HyperV后Docker运行不了怎么办?

1.背景 为了模拟真机&#xff0c;尝试安装了Nox夜神模拟器&#xff0c; 安装过程要求关闭Hyper-V。当时只是在程序安装卸载中关闭了系统服务。以为到时勾选上就好了。操作路径&#xff1a;控制面板\所有控制面板项\程序和功能\启用或关闭Windows功能\Hyper-V。 后来卸载掉了夜神…

代码随想录第四十七天|打家劫舍、打家劫舍Ⅱ、打家劫舍Ⅲ

题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 代码如下&#xff1a; 打家劫舍问题需要注意相邻房子不能偷&#xff0c;因此在偷与不偷的选择上可以归类为&#xff1a; 偷当前&#xff08;i&#xff09;的房子&#xff0c;则子问题变为前i-2个房子的偷取金额…

VMware虚拟机提示内存不足

VMware虚拟机&#xff0c;k8s集群搭建内存不足的问题 疑问&#xff1a;我的电脑是8G8G双通道的内存&#xff0c;当我在搭建k8s集群时给master-2G内存&#xff0c;node1-3G内存&#xff0c;node2-3G内存&#xff1b; 当依次打开虚拟机到node2时VM提示“物理内存不足&#xff0c;…

【第14章】spring-mvc之ajax

文章目录 前言一、准备二、单个值1.前端2.后端3. 结果 三、对象1.前端2.后端3. 结果 四、JSON对象1.前端2.后端3. 结果 五、JSON数组1.前端2.后端3. 结果 总结 前言 AJAX&#xff08;Asynchronous JavaScript and XML&#xff09;是一种用于创建快速动态网页的技术&#xff0c…

大模型微调实战之强化学习 贝尔曼方程及价值函数(一)

大模型微调实战之强化学习 贝尔曼方程及价值函数 强化学习&#xff08;RL&#xff09;是机器学习中一个话题&#xff0c;不仅在人工智能方面。它解决问题的方式与人类类似&#xff0c;我们每天都在学习并在生活中变得更好。 作为一名大模型学习者&#xff0c;当开始深入研究强…

2024蓝桥杯网络安全部分赛题wp

爬虫协议 题目给了提示访问robots.txt 会出三个目录 访问最后一个 点进去就flag{22560c15-577c-4c8b-9944-815473758bad} packet 下载附件&#xff0c;这个是流量包 放wireshark流量分析 搜http协议 发现有cat flag命令&#xff0c;直接看他返回的流量 最后base64解码即可…

Web服务器和Tomcat

Web介绍 对于http协议操作进行封装、简化web程序开发 部署web项目&#xff0c;对外提供上网信息浏览 Tomcat介绍 一个轻量级的web服务器 也称为web容器 Tomcat的文件夹介绍 下载地址&#xff1a;Apache Tomcat - Apache Tomcat 9 Software Downloads 安装&#xff1a;直…

嵌入式数据库SQLite 3配置使用详细笔记教程

0、惨痛教训 随着管理开发的项目体积越来越庞大&#xff0c;产品系统涉及的数据量也越来越多&#xff0c;并且伴随着项目不久就要交付给甲方了。如果项目的数据信息没有被妥善管理&#xff0c;后期设备的运行状态、操作状况等数据流信息不能被溯源&#xff0c;当出现了一些特殊…

typescript的入门到吐槽:看了typescript,发现前端真的卷,

typescript TypeScript 是一种由微软开发的自由和开源的编程语言。它是 JavaScript 的一个超集&#xff0c;而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程。 TypeScript 与 JavaScript 的区别 其实就是对JavaScript的封装&#xff0c;把一个弱类型语言封…

“王翦五讨赏地,萧何三贬其身”的背后,正是智者安身的处世之道

冯子曰&#xff1a;智者&#xff0c;术所以生也&#xff1b;术者&#xff0c;智所以转也。 智慧的人&#xff0c;从不蛮行横性&#xff0c;而是懂得如何在世道和自我之间谋得最佳的处境。 01、王翦五讨赏地 战国时期&#xff0c;秦始皇派王翦率六十万大军攻打楚国&#xff0…

【SpringBoot】 什么是springboot(一)?如何搭建springboot项目?

文章目录 SpringBoot第一章1、什么是springboot1、回顾ssm项目搭建流程2、springboot项目的优点2、搭建springboot项目方式1:方式2:第二章1、基本配置1、热部署2、注解3、端口配置application.properties特点application.yml特点注意4、环境配置springboot中的配置文件要求5、…