[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);

       }

    }
}
相关推荐
We་ct13 分钟前
LeetCode 211. 添加与搜索单词 - 数据结构设计:字典树+DFS解法详解
开发语言·前端·数据结构·算法·leetcode·typescript·深度优先
一叶落43813 分钟前
LeetCode 202. 快乐数(C语言详解 | 三种解法 | 哈希表 + 快慢指针)
c语言·数据结构·算法·leetcode·散列表
Z9fish26 分钟前
sse 哈工大 C 语言编程练习 39
c语言·数据结构·算法
丶小鱼丶28 分钟前
数据结构和算法之【二分查找】
java·数据结构·算法
忡黑梨31 分钟前
BUUCTF_reverse_[MRCTF2020]Transform
c语言·开发语言·数据结构·python·算法·网络安全
枳颜35 分钟前
LeetCode 466:统计重复个数
数据结构·算法·字符串
TYFHVB1236 分钟前
2026六大主流CRM横评,五大核心维度深度解析
大数据·前端·数据结构·人工智能
爱和冰阔落38 分钟前
【C++STL上】栈和队列模拟实现 容器适配器 力扣经典算法秘籍
数据结构·c++·算法·leetcode·广度优先
Gorgous—l39 分钟前
数据结构算法学习:LeetCode热题100-贪心算法篇(数组中的第K个最大元素、 前 K 个高频元素、数据流的中位数)
数据结构·学习·算法
一叶落43840 分钟前
LeetCode 300. 最长递增子序列(LIS)详解(C语言 | DP + 二分优化)
c语言·数据结构·c++·算法·leetcode