[Java][单列集合遍历合集]以五种遍历方式谈单列集合

List系列集合的五种遍历方式:

1.迭代器遍历 Itrator
2.列表迭代器
3.增强for
4.Lambda表达式来简化forEach
5.普通for

java 复制代码
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
import java.util.function.Consumer;

public class Main{
    public static void main(String[] args){
        /*
        List系列集合的五种遍历方式:
        1.迭代器遍历 Itrator
        2.列表迭代器
        3.增强for
        4.Lambda表达式来简化forEach
        5.普通for
         */
        //创建集合并且添加元素
        List<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");

        //1.迭代器
        Iterator<String> it =list.iterator();
        while(it.hasNext()){
            System.out.println(it.next());
        }

        //2.增强for的遍历方式
        for(String s:list){
            System.out.println(s);//这里的s是一个第三方变量 用来临时储存并且打印的 依次表示集合中的每一个元素
        }

        //4.Lambda表达式
        list.forEach(new Consumer<String>() {
            @Override
            public void accept(String s) {
                System.out.println(s);
            }
        });
        list.forEach(s->System.out.println(s));//这里是由匿名内部类修改的Lambda表达式形式出现的

       //5.普通for
       //size和get方法
       for(int i=0;i<list.size();i++){
           System.out.println(list.get(i));
       }

       //2.列表迭代器:是一个新的知识点
        //也称为 ListIterator 也是一个接口 相较于其他我们之前学习过的方法
        //我们现在来研究一下这个新的接口
        //ListIterator是一个Iterator的子接口
        //hasNext是原先一样的 Next是原先一样的
        //有一个add是新的方法
        //这里有hasPrevious和previous方法的方向是与hasNext和Next方向相反的
        //我们是不是回忆起了 这个在Iterator当中 移动到字符串最后一位就不会动了
        //如果你在list类型当中 你就可以使用previous和hasPrevious来回溯
        ListIterator<String> lit = list.listIterator();


       //在遍历的过程中可以添加元素 这是不同于Iterator的
       while(it.hasNext()){
           String str=it.next();
           if("bbb".equals(str)){
               //list.add("qqq");//这样是不可以的 不可以用集合来添加
               lit.add("qqq");//这样是可以的 你只能用迭代器本身的方法进行添加
           }

           System.out.println(str);

       }

    }
}
相关推荐
qeen8710 小时前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
图码10 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
我星期八休息10 小时前
IT疑难杂症诊疗室:AI时代工程师Superpowers进化论
linux·开发语言·数据结构·人工智能·python·散列表
漂流瓶jz11 小时前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva
你撅嘴真丑11 小时前
map 与 set容器的应用--话题焦点人物
数据结构
生成论实验室11 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
li16709027012 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
代码中介商14 小时前
数据结构开篇:从问题到解决方案
数据结构
AKDreamer_HeXY15 小时前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
Rabitebla15 小时前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法