List的介绍

1. 什么是List

List是一个接口,继承自Collection。

Collection也是一个接口,该接口中规范了后序容器中常用的一些方法。

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

2. 常见接口介绍

List中提供了好的方法,是常用方法如下:

|------------------------------------------|---------------------------|
| 方法 | 解释 |
| boolean add(E e) | 尾插 e |
| void add(int index, E element) | 将 e 插入到 index 位置 |
| boolean addAll(Collection 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 subList(int fromIndex, int toIndex) | 截取部分 list |

java 复制代码
package Demo03;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;

public class Test {
    public static void main(String[] args) {
        List<String> strings = new ArrayList<>();
//        boolean add(E e)	尾插 e
        strings.add("A");
        strings.add("B");
        strings.add("C");
        strings.add("D");
        strings.add("E");
        strings.add("F");
        System.out.println(strings);

//      void add(int index, E element)	将 e 插入到 index 位置
        strings.add(1, "H");
        System.out.println(strings);

//       boolean addAll(Collection c) 	尾插 c 中的元素
        List<String> strings1 = new ArrayList<>(Arrays.asList("A", "B", "C"));
        List<String> strings2 = new ArrayList<>(Arrays.asList("A", "B", "C"));
        strings1.addAll(strings2);
        System.out.println(strings1);

//        E remove(int index)	删除 index 位置元素
        strings.remove(2);
        System.out.println(strings);

//        boolean remove(Object o)	删除遇到的第一个 o
        strings.remove("A");
        System.out.println(strings);

//        E get(int index) 获取下标 index 位置元素
        System.out.println(strings.get(2));


//        E get(int index) 获取下标 index 位置元素
        strings.set(1, "G");
        System.out.println(strings);

//        void clear() 清空
        strings.clear();
        System.out.println(strings);

//        boolean contains(Object o) 判断 o 是否在线性表中
        List<String> strings3 = new ArrayList<>(Arrays.asList("ABC", "B", "C", "C", "D", "E"));
        System.out.println(strings3.contains("ABC"));
        System.out.println(strings3.contains("P"));

//        int indexOf(Object o) 返回第一个 o 所在下标
        System.out.println(strings3.indexOf("ABC"));


//        int lastIndexOf(Object o) 返回最后一个 o 的下标
        System.out.println(strings3.lastIndexOf("C"));

//        List<E> subList(int fromIndex, int toIndex) 截取部分 list
        System.out.println(strings3.subList(1, 3));
    }
}

3. List的使用

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

如果要使用,必须去实例化List的实现类。在集合框架中,ArrayList和LinkedList都实现了List接口。

相关推荐
papership9 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826529 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa9 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!9 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
丑八怪大丑9 小时前
Java数据结构与集合源码
数据结构
一个爱编程的人18 小时前
一个数是不是素数
数据结构·算法
忡黑梨18 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
地球资源数据云19 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
牢姐与蒯19 小时前
cpp数据结构之map
数据结构