在平时的开发过程中使用List的场景很多,你知道List的遍历有多少种方式?今天一起来梳理下List的几种遍历方式。这里以java.util.为例来演示。

这里有一个最简单的测试类,里边有一个main方法

package com.my.template.service;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
 * @date 2022/8/2 18:12
 */
public class TestList {
    public static void main(String[] args) {
        List list=new ArrayList();
        list.add("hello");
        list.add("ArrayList");
        list.add("!");
        simpleTraverse(list);
    }
}

1.最简单的方式

这种方式是最简单的,也是最容易想到的。

/**
     * 最简单的遍历方式
     * @param list
     */
    public static void simpleTraverse(List list){
        for(int i=0;i<list.size();i++){
            System.out.println(list.get(i));
        }
    }

这种方法就是把List当作一个数组,从数组的第一个位置开始循环到数组的最后位置,有以下几点需要注意,

i的初始值为0,因为数组的第一个下标为0;临界值为list的长度-1,也就是“i

打印结果为:

hello
ArrayList
!

这种方式初学者都会的遍历方式,下面看高级点。

2.的遍历方式

上面的遍历方式,下面来看下高级的遍历方法,

/**
     * 进阶版的遍历方式,foreach
     * @param list
     */
    public static void forEachTraverse(List list){
        for (String str:list) {
            System.out.println(str);
        }
    }

这种方式是利用的用法,很多人不清楚的底层是什么样子的,在idea中找到class文件,看下反编译过来的代码,

数组转list_数组转list三种方法_数组转list方法

从反编译过滤的代码可以看到底层其实是使用的迭代器的方式,也就是下面要说的遍历方式。

3.迭代器的遍历方式

List可以使用迭代器的方式进行遍历是有原因的,因为在list的实现类中均实现了接口。看下中对接口的实现,

数组转list方法_数组转list_数组转list三种方法

在中有静态内部类Itr,该类实现了接口。同时提供了()方法,

数组转list三种方法_数组转list_数组转list方法

这样就可以使用迭代器了。看下迭代器模式的遍历方式,

/**
     * 迭代器的遍历方式
     * @param list
     */
    public static void iteratorTraverse(List list){
        Iterator iterator=list.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }
    }

看下是不是也是很简单。下面看最后一种遍历方式,流式遍历。

4.流式的遍历方式

所谓流式的遍历,是java8提供的最新的方式,

/**
     * 流式遍历
     * @param list
     */
    public static void streamTraverse(List list){
        list.stream().forEach(str->{
            System.out.println(str);
        });
    }

是不是很简单,对于()的API后边会专门分析,这里知道这种遍历方式即可,有兴趣的可以先看看该种方式的实现。

总结,本文主要梳理里在日常的开发过程中对List的遍历方式,没有最好的方式只有适合自己的。

原文链接:

———END———
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,永久会员只需109元,全站资源免费下载 点击查看详情
站 长 微 信: nanadh666

声明:1、本内容转载于网络,版权归原作者所有!2、本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。3、本内容若侵犯到你的版权利益,请联系我们,会尽快给予删除处理!