[英]3 nested for-each loops as Java Stream (or better parallel stream)
在我目前正在进行的项目中,我们有三个嵌套 for 循环的结构:
List<OutputDataType> resultList = new ArrayList<>();
for (OrgStructureEntity product : products) {
for (String region : regions) {
for (SalesType salesType : SalesType.values()) {
resultList.addAll(new SalesRequest(getConnection(),
product.getProductMainGroup(), product.getSbu(), planYear, currentPeriod, region, salesType,
exchangeRates).calculateSalesKpis());
}
}
}
product 和 region 都是 Sets。 resultList 是一个带有“OutputDataType”对象的 ArrayList。 方法calculateSalesKpis() 还返回一个“OutputDataType”对象列表。 所有这些对象都应该添加到 resultList 中。 我想用并行流来做这一切以使其更快,但我没有比这更进一步:
products.stream()
.map(product -> regions.stream()
.map(region -> Arrays.stream(SalesType.values())
.map(salesType -> new SalesRequest(getConnection(),
product.getProductMainGroup(), product.getSbu(), planYear, currentPeriod, region, salesType,
exchangeRates).calculateSalesKpis())))
.
我现在不知道如何将其全部放入结果列表以及如何正确关闭流。 我希望你可以帮助我 :)
为了避免在 Stream> 上工作,您需要在执行集合之前使用flatmap
方法展平嵌套的Stream
结构:
products.stream()
.flatMap(product -> regions.stream()
.flatMap(region -> Arrays.stream(SalesType.values())
.flatMap(salesType -> new SalesRequest(getConnection(),
product.getProductMainGroup(), product.getSbu(), planYear, currentPeriod, region, salesType, exchangeRates).calculateSalesKpis().stream())))
.collect(Collectors.toList())
.
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.