Java8新特性stream循环

加油,新时代打工人!

java 复制代码
public static void main(String[] args) {
		HashMap<Integer,String> map =new HashMap<>();
		map.put(1,"小米");
		map.put(2,"小明");
		map.put(3,"小红");
		List<HashMap<Integer,String>> map2 =new ArrayList<>();
		map2.add(map);
		System.out.println("方式二>>map.entrySet().stream.forEach()遍历---Stream流遍历");
		for(HashMap<Integer,String> map3 :map2){
			map3.entrySet().stream().forEach((Map.Entry<Integer,String> entry) -> {
				System.out.print(entry.getKey());
				System.out.println(entry.getValue());

			});
		}
		System.out.println("方式一>>map.entrySet().stream.forEach()遍历---Stream流遍历");
		for (int j = 0; j < map2.size(); j++) {
			int finalJ = j;
			map2.get(j).entrySet().stream().forEach((Map.Entry<Integer,String> entry) -> {
				System.out.print(entry.getKey()+ finalJ);
				System.out.println(entry.getValue());

			});

		}
		System.out.println("map.keySet().stream.forEach()遍历---Stream流遍历");
		map.keySet().stream().forEach(key -> {
			System.out.println(map.get(key));
		});

	}
java 复制代码
import java.util.Arrays;
import java.util.List;

/**
	从lambda 表达式引用的本地变量必须是最终变量或实际上的最终变量
 * 我们想将一个Integer型的列表中的值求和,如果在外面定义一个全局变量用于记录最终的值,初始化为0
 */
public class Test_03 {
    public static void main(String[] args) {
        Integer[] arr={1,2,3,4,5};

        List<Integer> list = Arrays.asList(arr);

        Integer sum=0;

        //合法的,lambda表达式中可以引用值
        list.forEach(item-> System.out.println(item+"---"+sum));

        list.forEach(item->sum+=item);
        //Error: 从lambda 表达式引用的本地变量必须是最终变量或实际上的最终变量
        //说明:也就是说我们在这里引用的值item应该是不可变的,而我们在累加的过程中,改变了引用变量的值
    }
}
相关推荐
天天扭码15 分钟前
五天SpringCloud计划——DAY2之单体架构和微服务架构的选择和转换原则
java·spring cloud·微服务·架构
程序猿进阶15 分钟前
堆外内存泄露排查经历
java·jvm·后端·面试·性能优化·oom·内存泄露
FIN技术铺20 分钟前
Spring Boot框架Starter组件整理
java·spring boot·后端
小曲程序27 分钟前
vue3 封装request请求
java·前端·typescript·vue
陈王卜1 小时前
django+boostrap实现发布博客权限控制
java·前端·django
小码的头发丝、1 小时前
Spring Boot 注解
java·spring boot
java亮小白19971 小时前
Spring循环依赖如何解决的?
java·后端·spring
飞滕人生TYF1 小时前
java Queue 详解
java·队列
武子康1 小时前
大数据-230 离线数仓 - ODS层的构建 Hive处理 UDF 与 SerDe 处理 与 当前总结
java·大数据·数据仓库·hive·hadoop·sql·hdfs
武子康1 小时前
大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本
java·大数据·数据仓库·hive·hadoop·mysql