我有一张地图,并希望有一个整数,而不是双,但我似乎无法得到它的转换。我的问题似乎是“averagingInt”的一部分。我得到正确的值,我只是想圆下来。先感谢您。
public Map<String,Integer> executeSQL14(){
return records.stream()
.filter(p->p.getSource().equals("a") || p.getSource().equals("b"))
.filter(p->p.getDestination().equals("f") || p.getDestination().equals("h"))
.filter(p->p.getExtendedSecurityCheck().equals("n"))
.collect(Collectors.groupingBy(Record::getDestination, Collectors.averagingInt(Record::getWeight)));
}
你可能可以使用替代toMap
为:
public Map<String,Integer> executeSQL14(List<Record> records) {
return records.stream()
.filter(p -> p.getSource().equals("a") || p.getSource().equals("b"))
.filter(p -> p.getDestination().equals("f") || p.getDestination().equals("h"))
.filter(p -> p.getExtendedSecurityCheck().equals("n"))
.collect(Collectors.toMap(Record::getDestination, Record::getWeight, (a, b) -> (a + b) / 2));
}
或使用collectingAndThen
为可能进行附加的精加工操作:
public Map<String,Integer> executeSQL14(List<Record> records) {
return records.stream()
.filter(p -> p.getSource().equals("a") || p.getSource().equals("b"))
.filter(p -> p.getDestination().equals("f") || p.getDestination().equals("h"))
.filter(p -> p.getExtendedSecurityCheck().equals("n"))
.collect(Collectors.groupingBy(Record::getDestination,
Collectors.collectingAndThen(Collectors.averagingInt(Record::getWeight), Double::intValue)));
}