package com.lgx.jdk8.part02;
import java.util.*;
import java.util.stream.Collectors;
/**
* Collectors其它一些方法的使用
*/
public class Test11Collectors {
public static void main(String[] args) {
User user1 = new User("zhangsan", 60, 20);
User user2 = new User("lisi", 80, 23);
User user3 = new User("zhangsan", 80, 24);
User user4 = new User("wangwu", 50, 24);
User user5 = new User("wangwu2", 50, 24);
List<User> userList = Arrays.asList(user1, user2, user3, user4, user5);
//算出分数最小的那个并输出
userList.stream().collect(Collectors.minBy(Comparator.comparingInt(User::getScore))).ifPresent(System.out::println);
//算出分数最大的那个并输出(无法做到多个并列的时候求值)
Optional optional = userList.stream().collect(Collectors.maxBy(Comparator.comparingInt(User::getScore)));
//optional.isPresent(System.out::println);//isPresent是判断是否存在,不能接受参数
optional.ifPresent(System.out::println);//直接使用时ifPresent
//算出分数平均值并输出
double averagint = userList.stream().collect(Collectors.averagingInt(User::getScore));
System.out.println("averagint = " + averagint);
//算出分数总和并输出
int summingInt = userList.stream().collect(Collectors.summingInt(User::getScore));
System.out.println("summingInt = " + summingInt);
//算出汇总信息
IntSummaryStatistics intSummaryStatistics = userList.stream().collect(Collectors.summarizingInt(User::getScore));
System.out.println("intSummaryStatistics = " + intSummaryStatistics);
//拼接名字
String nameStrs = userList.stream().map(User::getName).collect(Collectors.joining(", "));
System.out.println("nameStrs = " + nameStrs);
//拼接名字,调用另外一个方法,可以加前缀和后缀
String nameStrs2 = userList.stream().map(User::getName).collect(Collectors.joining(", ", "[", "]"));
System.out.println("nameStrs2 = " + nameStrs2);
//分组:按照分数(返回的map的key是根据分组的条件来决定的,score是int,那么key就是Integer)
Map<Integer, List<User>> scoreUsers = userList.stream().collect(Collectors.groupingBy(User::getScore));
System.out.println("scoreUsers = " + scoreUsers);
//二级分组:线按照分数分组,返回一个Map<Integer, List<User>>, 在根据用户名分组
Map<Integer, Map<String, List<User>>> scoreNameUsers = userList.stream().collect(Collectors.groupingBy(User::getScore, Collectors.groupingBy(User::getName)));
System.out.println("scoreNameUsers = " + scoreNameUsers);
//分区,是否及格
Map<Boolean, List<User>> jigeUsers = userList.stream().collect(Collectors.partitioningBy(user -> user.getScore() >= 60));
System.out.println("jigeUsers = " + jigeUsers);
//二级分区,是否及格,及格里面是否大于80
Map<Boolean, Map<Boolean, List<User>>> youxiuUsers = userList.stream().collect(Collectors.partitioningBy(user -> user.getScore() >= 60, Collectors.partitioningBy(user -> user.getScore() >= 80)));
System.out.println("youxiuUsers = " + youxiuUsers);
//分区,是否及格,算出及格的个数
Map<Boolean, Long> jigeUserCount = userList.stream().collect(Collectors.partitioningBy(user -> user.getScore() >= 60, Collectors.counting()));
System.out.println("jigeUserCount = " + jigeUserCount);
//先按照名字分组,获取每个分组分数最小的
Map<String, User> UserCount = userList.stream().collect(Collectors.groupingBy(User::getName, Collectors.collectingAndThen(Collectors.minBy(Comparator.comparingInt(User::getScore)), Optional::get)));
System.out.println("UserCount = " + UserCount);
Map<String, Detail> Map = List.stream().collect(Collectors.toMap(Detail::getid, Function.identity()));
}
}
1、List<对象>转为List<String>
方式一:
List<String> ids = userList.stream().map(User::getId).collect(Collectors.toList());
方式二:
List<String> ids = users.stream().map(e -> e.getId()).collect(Collectors.toList());
//将list转map 【key为1个属性,value为1个属性】 (map的键重复不会报错,下面已经处理)
Map<String, String> map =
list.stream().collect(Collectors.toMap(
Student::getNo,
Student::getName,
(key1 , key2) -> key1
));
//将list转map 【key为多个属性,value为1个属性】 (map的键重复不会报错,下面已经处理)
Map<String, String> map =
list.stream().collect(Collectors.toMap(
obj -> obj.getNo() + "_" + obj.getName(),
Student::getName,
(key1 , key2) -> key1
));
Java 8中List转Map的多种方式
word
# mybatis-plus baomidou 配置
mybatis-plus:
mapper-locations: classpath:mapping/**/*Mapper.xml
type-aliases-package: com.mapper.pojo
global-config:
db-config:
#主键类型 0:"数据库ID自增",1:"该类型为未设置主键类型", 2:"用户输入ID",3:"全局唯一ID (数字类型唯一ID)", 4:"全局唯一ID UUID";
id-type: assign_id
# 默认数据库表下划线命名
table-underline: true
configuration:
# 返回类型为Map,显示null对应的字段
call-setters-on-nulls: true
# 这个配置会将执行的sql打印出来,在开发或测试的时候可以用
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl