java8 stream().map().collect()的Collectors.toList()、Collectors.toMap()、Collectors.groupingBy()的用法[通俗易懂]

java8 stream().map().collect()的Collectors.toList()、Collectors.toMap()、Collectors.groupingBy()的用法[通俗易懂]  现在有个集合:List<User>users=getUserList();  现在需要将这些user的id提取出来。这个很简单,for循环嘛,谁不会啊(不会吧不会吧,不会有人还不会用for循环的吧)。List<Long>idList=newArrayList<Long>();for(inti=0;i<users.size();i++){  idList.add(users.get(i).getId());}  

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、Collectors.toList()

  现在有个集合:

List<User> users = getUserList();

  现在需要将这些user的id提取出来。这个很简单,for循环嘛,谁不会啊(不会吧不会吧,不会有人还不会用for循环的吧)。

List<Long> idList = new ArrayList<Long>();

for(int i = 0; i < users.size(); i++){

  idList.add(users.get(i).getId());

}

  然而Java8有个更简便的方法,一行代码搞定:

List<Long> idList = users.stream().map(User::getId).collect(Collectors.toList());

其中有个User::getId,这个其实就是调用User类的getId()方法。

  再举个例子,将集合里的元素由小写变大写:

List<String> list = Arrays.asList("a", "b", "c", "d");

List<String> results = list.stream().map(String::toUpperCase).collect(Collectors.toList());

System.out.println(results); //{A, B, C, D}

二、Collectors.toMap()

  Collectors.toMap(),一般用于将一个List转换为Map。常见用法:

list.stream().collect(Collectors.toMap(Function keyMapper, Function valueMapper))

在这里插入图片描述

  可以接收2个、3个、4个参数,但是我一般只用2个的或者3个的就已经足够了。这里我也就只讲一个前两个用法,也就是2个参数的和3个参数的用法。

  第一个参数,用于指定key的Function。
  第二个参数,用于指定value的Function。
  第三个参数,若在转换中,出现多个相同的key,如何进行合并的Function。

1. 两个参数的用法

  现在有个User对象:

@Getter
@Setter
public class User{ 
   
	private Long id;
	private String name;
	private Integer age;

	public User(Long id, String name, Integer age) { 
   
        this.id = id;
        this.name = name;
        this.age = age;
    }
}

  然后进行以下操作:

List<User> userList = new ArrayList<>();
userList.add(new User(1, "张三", 18));
userList.add(new User(2, "李四", 19));
userList.add(new User(3, "王五", 18));
//将userList转化为key为id,value为User对象的map
Map<Long, User> map = userList.stream().collect(Collectors.toMap(User::getId, p -> p));

  Map<Long, User> map = userList.stream().collect(Collectors.toMap(User::getId, p -> p));这一步就是将userList 转换为key为id,value为User对象的map。

User::getId ===》 User对象的getId方法
p -> p ===》就是进来的是什么,最终就是什么,这里就是进来的是User对象,出去的也就是User对象

  而这时map里的(模拟)值是:

{ 
   
	1: User(1, "张三", 18)
	2: User(2, "李四", 19)
	3: User(3, "王五", 18)
}

  还可以换一下:

Map<Long, String> map = userList.stream().collect(Collectors.toMap(User::getId, User::getName));

  这个获取的就是key为id,value为name的map了。

2. 三个参数的用法

  还是沿用上面那个例子,如果这个时候你想获取key是age,value是name的map呢?如果你还是沿用上面的方法,就会出问题了,因为有两个age是 18 的数据,也就是存在重复的key,会直接报错,想不报错的话,就可以利用第三个参数了。

Map<Integer, String> map = userList.stream().collect(Collectors.toMap(User::getAge, User::getName, (a, b) -> b));

  (a, b) -> b的意思就是,如果存在重复的,永远取后面一个

  这时,map里的值就是:

{ 
   
	18: "王五"
	19: "李四"
}

三、Collectors.groupingBy()

  还是沿用上面那个例子。当你想获取key是age的map,又不想覆盖掉重复项数据,这个时候就可以用 Collectors.groupingBy 了。

Map<Integer, List<User>> map = userList.stream().collect(Collectors.groupingBy(User::getAge));

  可以看到,这次的返回值变成了 Map<Integer, List> 了,也就是说,变成了key是age,value是User对象的集合了。这时,map里的值就变成了:

{ 
   
	18: [User(1, "张三", 18), User(3, "王五", 18)]
	19: [User(2, "李四", 19)]
}

以上就是这三种Collectors的用法了,如果你有什么疑点,或者是觉得博主有哪里写的不对的,欢迎在下方留言讨论哦~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/171503.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月20日 下午8:16
下一篇 2022年8月20日 下午8:36


相关推荐

  • table 能设圆角 css,table&css圆角边框效果

    table 能设圆角 css,table&css圆角边框效果挺好用的放在最下面比较好看所以就一个下圆角的实例上圆角按照代码很容易做 图传不上来 head 区 body font 100 01 TrebuchetMS Verdana Arial sans serif h1 h2 p margin 010px h1 font size 250 color FFF h2 font size 200 color f0f0f0 p

    2026年3月17日
    2
  • 0.96寸OLED12864显示屏设计方案(原理图+PCB+BOM表+程序)

    0.96寸OLED12864显示屏设计方案(原理图+PCB+BOM表+程序)一 简介 OLED 屏幕作为一种新型的显示技术 其自身可以发光 亮度 对比度高 功耗低 在当下备受追捧 而在我们正常的显示调整参数过程中 我们越来越多的使用这种屏幕 我们使用的一般是分辨率为 128 64 屏幕尺寸为 0 96 寸 由于其较小的尺寸和比较高的分辨率 让它有着很好的显示效果和便携性

    2026年3月26日
    2
  • 气动手套结构

    气动手套结构

    2026年3月15日
    3
  • 数据库 关系代数

    数据库 关系代数关系代数是一种抽象的查询语言关系代数的运算对象与运算结果都是关系集合运算把关系看出元组的集合 以元组作为集合中的元素进行集合运算集合运算是典型的二目运算 除笛卡尔积外 交 并 差操作都需满足相容性 具有相同的度 即两个关系的属性名 属性数量必须一致 关系 R 中第 i 个属性和关系 S 中第 i 个属性必须来自同一域 并 Union 运算 R S t t

    2026年3月18日
    2
  • 什么是51单片机最小系统?

    什么是51单片机最小系统?什么是单片机最小系统?说白了就是单片机能正常工作的最简单的电路。当然有些芯片自己上电就能工作,这里我们介绍的是51单片机的最小系统电路。通常51单片机的最小电路包括:单片机、晶振、复位电路。下面我们逐一介绍。一、单片机如上图所示,其各个引脚功能如下:1~8:P1对应的IO口(可编程输入输出口)。9:RST复位引脚,引脚上出现2个机器周期的高电平将使单片机复位。10~17:P3对应的IO口。18:XTAL2晶振输出端。19:XTAL1晶振输入端。20:GND电源地。..

    2022年6月23日
    33
  • 什么是Scrum的增量?

    什么是Scrum的增量?英文原文 WhatisanIncr 了解 Scrum 工件 增量 increment 如 Scrum 指南中所述 Increment 是 Sprint 期间完成的所有 ProductBackl 项目的总和 以及所有先前 Sprint 的增量值 在 Sprint 结束时 新增量必须是 完成 这意味着它必须处于可用

    2025年11月9日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号