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接口。

相关推荐
C++忠实粉丝4 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O5 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
代码雕刻家6 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
Kalika0-07 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
代码雕刻家7 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
小字节,大梦想9 小时前
【C++】二叉搜索树
数据结构·c++
我是哈哈hh9 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
丶Darling.10 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树
labuladuo52010 小时前
Codeforces Round 977 (Div. 2) C2 Adjust The Presentation (Hard Version)(思维,set)
数据结构·c++·算法
Indigo_code10 小时前
【数据结构】【链表代码】合并有序链表
数据结构·windows·链表