1:排序
//正序
pointList.sort(Comparator.comparing(MemergencyLeaderPoint::getPointTime));
//倒序
pointList.sort(Comparator.comparing(MemergencyLeaderPoint::getPointTime).reversed());
//Map排序
scheduleMap = scheduleMap.entrySet().stream().sorted(Map.Entry.comparingByKey()).collect(Collectors
.toMap(Map.Entry::getKey, Map.Entry::getValue, (oldValue, newValue) -> oldValue,
LinkedHashMap::new));
2:分组
//根据getSchedule值进行分组
pointList.stream().collect(Collectors.groupingBy(ScheduleDetail::getSchedule));
3:分组统计
//根据getShortName字段分组并计算每组多少条数据
pointList.stream().collect(Collectors.groupingBy(Enterprise::getShortName, Collectors.counting()));
4:过滤
//过滤集合中无用数据,一般用于集合中某个属性为空时过滤掉这条信息
mscheduleDetailList.parallelStream().filter(mscheduleDetail -> mscheduleDetail.getLeader() != null).collect(Collectors.toList());
5:统计
//统计集合中某个字段/集合的数量
enterpriseList.stream().mapToInt(enterprise -> enterprise.getHazardsSet().size()).sum();
6:根据key分组的小demo
//1:根据集合中某个值做分组,返回一个Map集合,key为分组值,value为集合
Map<String, List<ReportSensorAlarm>> historySensorAlarmMap = historyArarmSensorList.stream().collect(Collectors.groupingBy(ReportSensorAlarm::getEnterpriseName));
//2:遍历集合
for (String enterpriseName : historySensorAlarmMap.keySet()) {
//3:进行业务逻辑操作
ReportSensor reportSensor = new ReportSensor();
reportSensor.setEnterpriseName(enterpriseName);
List<ReportSensorAlarm> alarmList = historySensorAlarmMap.get(enterpriseName);
alarmList.sort(Comparator.comparing(ReportSensorAlarm::getCreateTime));
reportSensor.setCount(alarmList.stream().collect(Collectors.groupingBy(ReportSensorAlarm::getSensorCode)).size());
reportSensor.setReportSensorAlarmList(alarmList);
historySensorList.add(reportSensor);
}