我有一个List<BatchDTO>与以下类
public class BatchDTO {
private String batchNumber;
private Double quantity;
.
.
//Getters and setters
}
如果 batchNumber 重复,我要做的是总结总数。我使用 LinkedHashMap 来实现它,并进行了迭代。但我想要的是一种更优化的方式。我可以使用流以优化的方式执行此操作吗?
private static List<BatchDTO > getBatchDTO (Map<String, BatchDTO > batchmap) {
return batchmap.values().stream().collect(Collectors.toList());
}
private static Map<String, BatchDTO > getBatchMap(List<BatchDTO > batchList, Map<String, BatchDTO > batchMap) {
for (BatchDTO batchDTO : batchList) {
batchMap = getBatchMap(batchMap, batchDTO );
}
return batchMap;
}
private static Map<String, BatchDTO > getBatchMap(Map<String, BatchDTO > batchMap, BatchDTO batchObject) {
String batchCode = batchObject.getBatchNumber();
if(!batchMap.containsKey(batchCode)) {
batchMap.put(batchCode, batchObject);
} else {
batchObject.setQuantity(getTotalQuantity(batchMap,batchObject));
batchMap.put(batchCode, batchObject);
}
return batchMap;
}
private static Double getTotalQuantity(Map<String, BatchDTO > batchmap, BatchDTO batchObject) {
return batchmap.get(batchObject.getBatchNumber()).getQuantity() + batchObject.getQuantity();
}
九州编程
饮歌长啸
相关分类