使用foreach和stream遍历并修改List列表

使用foreach和stream遍历并修改List列表

1.使用foreach

java 复制代码
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class TestList {
    public static void main(String[] args) {
        List list = new ArrayList<>();
        // 示例数据
        Map map = new HashMap<>();
        map.put(10, "lihua0");
        map.put(11, "lihua1");
        map.put(12, "lihua2");
        list.add(map);
        System.out.println("初始化list: "+ list.toString());
        // 使用 forEach 替换名字并打印
        for (Object map1 : list) {
            Map map11 = (Map) map1;
            if (map11.get(11).equals("lihua1") || map11.get(12).equals("lihua2")  ) {
                map11.put(11,"Tom");
                map11.put(12,"Jimi");
            }
        }
        System.out.println("foreach循环赋值后的list: "+ list.toString());
        // 使用 stream 进行替换时,因为 stream 是不可变的,你不能直接在原列表中修改元素。相反,你需要创建一个新的列表来存储修改后的元素。
       List newList = (List) list.stream().map(items -> {
           Map map11 = (Map) items;
           if (map11.get(10).equals("lihua0")) {
               map11.put(10,"莉莉");
           }
           return map11;
       }).collect(Collectors.toList());
        System.out.println("stream循环赋值后的list: "+ newList.toString());
    }
}

结果:

复制代码
初始化list:[{10=lihua0, 11=lihua1, 12=lihua2}]
foreach循环赋值后的list[{10=lihua0, 11=Tom, 12=Jimi}]

2.使用stream

复制代码
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class TestList {
    public static void main(String[] args) {
        List list = new ArrayList<>();
        // 示例数据
        Map map = new HashMap<>();
        map.put(10, "lihua0");
        map.put(11, "lihua1");
        map.put(12, "lihua2");
        list.add(map);
        System.out.println("初始化list: "+ list.toString());
        
        // 使用 stream 进行替换时,因为 stream 是不可变的,你不能直接在原列表中修改元素。相反,你需要创建一个新的列表来存储修改后的元素。
       List newList = (List) list.stream().map(items -> {
           Map map11 = (Map) items;
           if (map11.get(10).equals("lihua0")) {
               map11.put(10,"莉莉");
           }
           return map11;
       }).collect(Collectors.toList());
        System.out.println("stream循环赋值后的list: "+ newList.toString());
    }

    // 打印新的列表
        newList.forEach(System.out::println); 
}

结果:

复制代码
stream循环赋值后的list: [{10=莉莉, 11=Tom, 12=Jimi}]
相关推荐
Zsy_05100314 小时前
【数据结构】二叉树OJ
数据结构
程序员东岸16 小时前
《数据结构——排序(中)》选择与交换的艺术:从直接选择到堆排序的性能跃迁
数据结构·笔记·算法·leetcode·排序算法
牢七16 小时前
数据结构11111
数据结构
Ayanami_Reii16 小时前
进阶数据结构应用-一个简单的整数问题2(线段树解法)
数据结构·算法·线段树·延迟标记
CoderYanger19 小时前
C.滑动窗口-越短越合法/求最长/最大——2958. 最多 K 个重复元素的最长子数组
java·数据结构·算法·leetcode·哈希算法·1024程序员节
Sunny_Future20 小时前
list()函数完全指南:用法、场景与实战
list
不会c嘎嘎20 小时前
【数据结构】AVL树详解:从原理到C++实现
数据结构·c++
却话巴山夜雨时i20 小时前
394. 字符串解码【中等】
java·数据结构·算法·leetcode
惊鸿.Jh20 小时前
503. 下一个更大元素 II
数据结构·算法·leetcode
客梦21 小时前
数据结构-栈与队列
数据结构·笔记