/** * 将一个指定类型对象的集合按照自定义的一个操作分组; 每组对应一个List、最终返回结果类型是:List<List<T>>
*
* @param <T>
*/staticclassGroupToListimplementsCollector>, List>> {
/** * 集合中对象两两比较,满足自定义的条件(operation结果返回true),便将这两个元素分为一组
*/privateBiFunction operation;
publicGroupToList(BiFunction operation) {
super();
this.operation = operation;
}
@Override
publicBiConsumer>, T> accumulator() {
return(c, t) -> {
booleanadded =false;
for(List cc : c) {
for (T ccc : cc) {
if (operation.apply(ccc, t)){
cc.add(t);
added =true;
}
break;
}
if (added)
break;
continue;
}
if(!added) {
ArrayList list =newArrayList();
list.add(t);
c.add(list);
}
};
}
@Override
publicSet characteristics() {
/* Set<java.util.stream.Collector.Characteristics> emptySet = Collections.emptySet();
*/return Collections.unmodifiableSet(EnumSet.of(Characteristics.IDENTITY_FINISH));
}
@Override
publicBinaryOperator>> combiner() {
return(l1,l2) -> {l2.addAll(l1);return l2;};
}
@Override
publicFunction>, List>> finisher() {
returnp -> p;
}
@Override
publicSupplier>> supplier() {
return() ->newArrayList>();
} 欢迎工作一到五年的Java工程师朋友们加入Java群: 891219277
群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!