Java List 集合

怀旧网个人博客网站地址:怀旧网,博客详情:Java List 集合

List 集合的特点

List 集合的特有方法

因为List是Collection 的子类,所以List也直接继承了所有的Collection 的方法。

List 集合方法代码测试

创建集合对象

因为List也是接口,所以同样不能直接对List进行实例化-这里还是使用ArrayList子类来进行实例化

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();
}

add方法

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();

    list.add(new Student("cat", 1));
    list.add(new Student("age", 2));
    list.add(1, new Student("age", 2));

    System.out.println(list);
}

​ 这边第一次和第二次的添加方式实际上是使用的父类Collection的add方法,但是在第三行添加方法才是使用List自己特有的添加方法。

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();

    list.add(1, new Student("age", 2));

    System.out.println(list);
}

注意:在使用List的add方法时直接添加数据的时候,索引的位置上面的前一个位置必须有元素,要是没有就会报错IndexOutOfBoundsException


remove方法

List 中的remove方法通过下标进行元素删除,当元素被删除后-要是删除成功会返回删除后的元素。

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();

    list.add(new Student("cat", 1));
    list.add(new Student("age", 2));
    list.add(1, new Student("age", 2));

    list.remove(1);

    System.out.println(list);
}

List 自己的remo方法,是直接删除下标所在位置的元素。

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();

    list.add(new Student("cat", 1));
    list.add(new Student("age", 2));
    list.add(1, new Student("age", 2));

    list.remove(3);

    System.out.println(list);
}

注意:在使用删除的时候,要是索引位置超出了当前属于总长度的大小,就会报错IndexOutOfBoundsException

remove方法删除int类型测试

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    list.remove(1);

    System.out.println(list);
}

在删除int类型的数据时:只能够删除下标的元素,而不是删除指定值的元素-如果想删除指定值,可以通过下面的方式实现:

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    list.remove(new Integer(1));

    System.out.println(list);
}

这里是创建一个Integer的对象来进行删除,就可以实现删除指定元素值的删除。


set 方法

在执行成功set方法后,会返回被修改后的元素数据。

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();

    list.add(new Student("cat", 1));
    list.add(new Student("age", 2));
    list.add(1, new Student("age", 2));

    list.set(1, new Student("aa", 12));

    System.out.println(list);
}

方法作用是修改当前的索引位置的值。

注意:当修改位置索引大于当前元素最大下标时同上也会报错IndexOutOfBoundsException-这边就不做演示了。


get 方法

复制代码
public static void main(String[] args){
    List<Student> list = new ArrayList<>();

    list.add(new Student("cat", 1));
    list.add(new Student("age", 2));
    list.add(1, new Student("age", 2));

    System.out.println(list.get(1));
}

get 方法是用来获取当前下标位置的元素,同理当下标元素大小超过元素最大下标同样会报错IndexOutOfBoundsException

List 集合的遍历方式

以上就是List集合的5种遍历方式--在Collection中实现过其中的三种,可以参考:网页链接

列表迭代器遍历

和Collection 方法一样可以进行迭代输出--注意获取迭代器对象的时候是调用listIterator()方法。。

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    ListIterator<Integer> iterator = list.listIterator();

    while (iterator.hasNext()){
        Integer data = iterator.next();
        System.out.println(data);
    }
}

重点介绍新增的方法:

previous 和 hasPrevious 方法

作用: 可以实现让指针像前移,可以实现倒序的遍历

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    ListIterator<Integer> iterator = list.listIterator();

    while (iterator.hasNext()){
        Integer data = iterator.next();
        System.out.println(data);
    }

    System.out.println("=================");

    while (iterator.hasPrevious()){
        Integer data = iterator.previous();
        System.out.println(data);
    }
}

注意:和next方法一样,当指针在起始位置时调用previous方法就会发生报错(因为当前指针的前一个位置是没有数据的)

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    ListIterator<Integer> iterator = list.listIterator();
    Integer data = iterator.previous();
}

新增add方法-和Collection一样需要用迭代器进行添加方法例如:

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    ListIterator<Integer> iterator = list.listIterator();

    while(iterator.hasNext()){
        Integer data = iterator.next();

        if(data.equals(1)){
            iterator.add(4);
        }
    }

    System.out.println(list);
}

同理,在迭代途中使用list的add方法同样会报错

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    ListIterator<Integer> iterator = list.listIterator();

    while(iterator.hasNext()){
        Integer data = iterator.next();

        if(data.equals(1)){
            list.add(4);
        }
    }

    System.out.println(list);
}

删除方法也同Collection一样

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    ListIterator<Integer> iterator = list.listIterator();

    while(iterator.hasNext()){
        Integer data = iterator.next();

        if(data.equals(1)){
            iterator.remove();
        }
    }

    System.out.println(list);
}

普通for循环遍历

复制代码
public static void main(String[] args){
    List<Integer> list = new ArrayList<>();

    list.add(1);
    list.add(2);
    list.add(3);

    for (int i = 0; i < list.size(); i++) {
        System.out.println(list.get(i));
    }
}

List 遍历总结

相关推荐
寻道码路2 小时前
LangChain4j Java AI 应用开发实战(四):提示词工程进阶 - 模板化与结构化 Prompt 设计
java·人工智能·ai·prompt·aigc
lcreek7 小时前
Java 反序列化漏洞深度解析(一):从URLDNS到真正的DNS探测
java·反序列化漏洞
杰克尼7 小时前
天机学堂复习总结(day03-day04)
java·开发语言·redis·elasticsearch·spring cloud
x***r1518 小时前
jdk-11.0.16.1_windows使用步骤详解(附JDK 11环境变量配置与验证教程)
java·开发语言·windows
弹简特8 小时前
【Java项目-轻聊】01-项目演示+项目介绍+准备工作+项目源码
java
luck_bor8 小时前
File类&递归作业
java·开发语言
武子康9 小时前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现
java·后端
花椒技术10 小时前
企业内部 Agent 落地复盘:Gateway、Skill 和二次确认如何串起受控业务执行
后端·agent·ai编程
REDcker11 小时前
Linux OverlayFS详解
java·linux·运维
玖釉-11 小时前
下一个排列:从字典序到原地算法的完整推导
数据结构·c++·windows·算法