【数据结构】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,第一时间获取新鲜的知识。

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

相关推荐
SandySY16 分钟前
品三国谈人性
算法·架构
敢敢J的憨憨L23 分钟前
GPTL(General Purpose Timing Library)使用教程
java·服务器·前端·c++·轻量级计时工具库
小欣加油25 分钟前
leetcode 62 不同路径
c++·算法·leetcode·职场和发展
夏鹏今天学习了吗25 分钟前
【LeetCode热题100(38/100)】翻转二叉树
算法·leetcode·职场和发展
夏鹏今天学习了吗26 分钟前
【LeetCode热题100(36/100)】二叉树的中序遍历
算法·leetcode·职场和发展
DTS小夏30 分钟前
算法社Python基础入门面试题库(新手版·含答案)
python·算法·面试
Mr.Ja1 小时前
【LeetCode热题100】No.11——盛最多水的容器
算法·leetcode·贪心算法·盛水最多的容器
sg_knight1 小时前
Spring Cloud与RabbitMQ深度集成:从入门到生产级实战
java·spring boot·spring·spring cloud·消息队列·rabbitmq·stream
冷徹 .1 小时前
2024ICPC区域赛香港站
数据结构·c++·算法
Chan162 小时前
批处理优化:从稳定性、性能、数据一致性、健壮性、可观测性五大维度,优化批量操作
java·spring boot·后端·性能优化·java-ee·intellij-idea·优化