java8 stream的groupingBy操作用法:
直接上链接:java8中的Collectors.groupingBy用法
关于使用Collectors.groupingBy无法按null值分组问题:
解决:(转载自Java8 stream 操作 GroupBy 设置键允许为null)
1.使用Collectors.groupingBy时,如果分组的 key 为 null,会抛出异常,可以写如下工具类规避这个问题:
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collector;
import java.util.stream.Collectors;
/**
* Java8 stream操作 GroupBy 设置键允许为null
*/
public class StreamGroupByUtil {
public static <T, A> Collector<T, ?, Map<A, List<T>>> groupByWithNullKeys(Function<? super T, ? extends A> classifier) {
return Collectors.toMap(
classifier,
Collections::singletonList,
(List<T> oldList, List<T> newEl) -> {
List<T> newList = new ArrayList<>(oldList.size() + 1);
newList.addAll(oldList);
newList.addAll(newEl);
return newList;
}
);
}
}
2.使用方式:
Map<Integer, List<ClassA>> map = classAList.stream()
.collect(StreamGroupByUtil.groupByWithNullKeys(ClassA::getParentId));
关于使用Collectors.groupingBy()输出乱序问题:
//将列表数据按日期进行分组
Map<Date, List<SilhouetteModel>> silhouetteListByDate = silhouetteModelList.parallelStream()
.collect(Collectors.groupingBy(SilhouetteModel::getDate));
通过源码可以发现 groupingBy 调用是内部自己创建了一个 HashMap ( HashMap::new),所以上述代码输出的Map是HashMap,而HashMap不是按顺序存的,就会造成Map遍历输出时与原来List的顺序不一致问题。
解决:使用LinkedHashMap,可以保证分组后顺序不变,如下
//将列表数据按日期进行分组
Map<Date, List<SilhouetteModel>> silhouetteListByDate = silhouetteModelList.parallelStream()
.collect(Collectors.groupingBy(SilhouetteModel::getDate, LinkedHashMap::new, Collectors.toList()));