业务场景:我们经常会把一个list<Dto> 对象类集合,转换成一个map集合,例如一个问题单集合 list<proVo>, 我们需要转换成 一个map集合,key就指定 问题单类的某个字段,比如问题单号 no, value值就是对应的整个问题单类对象,{"no001":问题单类 包含全部属性信息} ,那么就可以用到 的流式处理方法了,将list流转换成map集合
举例:
1.问题表单集合 list<proVo>,进行转换
- 第一个参数:proVo::getId, 表示选择proVo的Id作为map的key值;
- 第二个参数:t->t 表示选择将原来的对象作为Map的value值
- 第三个参数:(a,b)->a中,如果a与b的key值相同,选择a作为那个key所对应的value值,a参数在前面,表示是前一个集合元素,按前一个元素的值来覆盖。也可以选择b,也就是集合中较后的元素的值来覆盖。避免key重复而报错,所以重复key的时候,需要第三个参数指定
//根据 问题单id 和 问题名称name 将其转成 Map 集合
//形如: {"no01":"测试问题", "mo02":"生产问题"}
Map<Long, String> map = ().collect((proVo::getId, proVo::getName));
//根据 id 和 对象自己 转成 Map 集合
//这里的 () 等价于 t -> t,也可以写成这种形式,就是将对象自己返回。
Map<Long, proVo> map = ().collect((proVo::getId, ()));
2.防止key重复报错
一般toMap时只用到两个参数,第一个设定Key,第二个设定value。但如果Key重复的话,那就需要用到第三个参数,可以这么写(k1, k2)-> k1。
什么意思呢,就是说如果k1和k2的key都相同,那么只取k1的值去覆盖之前的值,也可以改为取k2的值,这样就解决了duplicate key的问题如果重复了key值,而没有设定第三个参数解决重复问题,就会报错
Map<Long, String> map = ().collect((proVo::getId, proVo::getName, (k1, k2) -> k1));