【数据结构】List介绍

目录

[1. 什么是List](#1. 什么是List)

[2. 常见接口介绍](#2. 常见接口介绍)

[3. List的使用](#3. List的使用)


1. 什么是List

在集合框架中,List是一个接口,继承自Collection。 此时extends意为拓展

Collection也是一个接口,该接口中规范了后序容器中常用的一些方法,具体如下所示:

Iterable也是一个接口,表示实现该接口的类是可以逐个元素进行遍历的,具体如下:

List的官方文档

站在数据结构的角度来看,List就是一个线性表,即n个具有相同类型元素的有限序列,在该序列上可以执行增删改查以及变量等操作。

2. 常见接口介绍

List中提供了好的方法,具体如下:

虽然方法比较多,但是常用方法如下

|-----------------------------------------------|---------------------------|
| 方法 | 解释 |
| boolean add(E e) | 尾插 e |
| void add(int index, E element) | 将 e 插入到 index 位置 |
| boolean addAll(Collection<? extends E> c) | 尾插 c 中的元素 |
| E remove(int index) | 删除 index 位置元素 |
| boolean remove(Object o) | 删除遇到的第一个 o |
| E get(int index) | 获取下标 index 位置元素 |
| E set(int index, E element) | 将下标 index 位置元素设置为 element |
| void clear() | 清空 |
| boolean contains(Object o) | 判断 o 是否在线性表中 |
| int indexOf(Object o) | 返回第一个 o 所在下标 |
| int lastIndexOf(Object o) | 返回最后一个 o 的下标 |
| List<E> subList(int fromIndex, int toIndex) | 截取部分 list |

3. List的使用

注意:List是个接口,并不能直接用来实例化。

  • 如果要使用,必须去实例化List的实现类。
  • 在集合框架中,ArrayList和LinkedList都实现了List接口。
  • ArrayList 和 LinkedList 是实体类,继承以及实现了上述的抽象类与接口(重写了方法),所以里面包含的方法最多。

我们要想了解这些方法,必须了解背后的数据结构,所以我们接下来的重点是讲一下这个具体类的数据结构,然后回过来给大家使用一下这个方法!!!

具体使用参考下一篇博客。


好啦Y(^o^)Y,本节内容到此就结束了。

后续还会持续更新数据结构与算法方面的内容,还请大家多多关注本up,第一时间获取新鲜的知识。

如果觉得文章不错,别忘了一键三连哟!

相关推荐
ch.ju2 分钟前
Java程序设计(第3版)第二章——java的数据类型:字符 char
java
尘世壹俗人3 分钟前
idea提交git版本由于中文文件名卡死不动
java·git·intellij-idea
学习永无止境@6 分钟前
Sobel边缘检测的MATLAB实现
图像处理·opencv·算法·计算机视觉·fpga开发
深挖派6 分钟前
IntelliJ IDEA 2026.1 安装配置与高效开发环境搭建 (保姆级图文教程)
java·ide·intellij-idea
c++逐梦人10 分钟前
记忆化搜索(DFS)
算法·深度优先
阿Y加油吧10 分钟前
二分查找进阶:搜索二维矩阵 & 查找元素首尾位置 深度解析
线性代数·算法·矩阵
起个名特麻烦13 分钟前
SpringBoot全局配置LocalDate/LocalTime/LocalDateTime的序列化和反序列化
java·spring boot·后端
SEO-狼术15 分钟前
Visualize Org Charts and Decision Trees in WinForms
算法·决策树·机器学习
UltraLAB-F17 分钟前
GPU显存不足时的分配策略:渲染与仿真的显存争夺战解决方案
图像处理·算法·3d·ai·硬件架构
高斯林.神犇18 分钟前
四、依赖注入.spring
java·后端·spring