Java 8 Lambda - 两个列表的交集
Java 8 Lambda - Intersection of Two Lists
我正在尝试根据某些条件并执行一些步骤来查找两个列表中的 intersection
。找不到方法(学习阶段):)
Double totalAmount = 0.00d;
Double discount = 0.00d;
List<OrderLineEntry> orderLineEntryList = orderEntry.getOrderReleases().stream()
.flatMap(orderReleaseEntry -> orderReleaseEntry.getOrderLines().stream())
.filter(orderLineEntry -> orderLineEntry.getStatus().equals("PP") || orderLineEntry.getStatus().equals("PD"))
.collect(Collectors.toList());
for (OrderLineEntry orderLineEntry : orderLineEntryList) {
for (SplitLineEntry splitLineEntry : splitReleaseEntry.getLineEntries()) {
if (splitLineEntry.getOrderLineId().equals(orderLineEntry.getId()) && splitLineEntry.getStatusCode() != "PX") {
totalAmount += orderLineEntry.getFinalAmount();
couponDiscount += orderLineEntry.getCouponDiscount() == null ? 0.00d : orderLineEntry.getCouponDiscount();
}
}
}
如你所见,逻辑很简单
根据某些过滤器 list
从订单中获取所有项目并与另一个 list
相交并做一些事情。
最简单的方法是:
List<T> intersect = list1.stream()
.filter(list2::contains)
.collect(Collectors.toList());
I need to compare them on assume list1.id == list2.fk_id
先建立一套fk_id;
Set<Integer> orderLineEntrSet = orderEntry.getOrderReleases().stream()
.flatMap(orderReleaseEntry ->
orderReleaseEntry.getOrderLines().stream())
.filter(orderLineEntry -> {
String s = orderLineEntry.getStatus();
return "PP".equals(s) || "PD".equals(s);
})
.map(e -> e.getId())
.collect(Collectors.toSet());
double[] totalAmount = { 0.0 };
double[] couponDiscount = { 0.0 };
orderLineEntryList.stream()
.flatMap(sre -> sre.getLineEntries().stream())
.filter(ole -> orderLineEntrySet.contains(ole.getOrderLineId())
.filter(ole -> !"PX".equals(ole.getStatusCode()))
.forEach(ole -> {
totalAmount[0] += ole.getFinalAmount();
if (ole.getCouponDiscount() != null)
couponDiscount[0] += ole.getCouponDiscount();
});
您可以通过使用 reduce 函数来避免使用对数组对象的引用。例如查看 Collectors.averagingDouble 是如何实现的。但我觉得这更复杂。
注意:这是 O(N),使用一组 ID 而不是使用匹配 ID 的列表,这将是 O(N^2)
List<T> intersect = list1.stream().filter(set1::contains).collect(Collectors.toList());
只要 T
是 String
、Integer
、Float
等,这就有效,其中 equals 和 HashCode 方法很简单。但是如果T
是一个自定义对象,我们需要实现HashCode & equals
我正在尝试根据某些条件并执行一些步骤来查找两个列表中的 intersection
。找不到方法(学习阶段):)
Double totalAmount = 0.00d;
Double discount = 0.00d;
List<OrderLineEntry> orderLineEntryList = orderEntry.getOrderReleases().stream()
.flatMap(orderReleaseEntry -> orderReleaseEntry.getOrderLines().stream())
.filter(orderLineEntry -> orderLineEntry.getStatus().equals("PP") || orderLineEntry.getStatus().equals("PD"))
.collect(Collectors.toList());
for (OrderLineEntry orderLineEntry : orderLineEntryList) {
for (SplitLineEntry splitLineEntry : splitReleaseEntry.getLineEntries()) {
if (splitLineEntry.getOrderLineId().equals(orderLineEntry.getId()) && splitLineEntry.getStatusCode() != "PX") {
totalAmount += orderLineEntry.getFinalAmount();
couponDiscount += orderLineEntry.getCouponDiscount() == null ? 0.00d : orderLineEntry.getCouponDiscount();
}
}
}
如你所见,逻辑很简单
根据某些过滤器 list
从订单中获取所有项目并与另一个 list
相交并做一些事情。
最简单的方法是:
List<T> intersect = list1.stream()
.filter(list2::contains)
.collect(Collectors.toList());
I need to compare them on assume list1.id == list2.fk_id
先建立一套fk_id;
Set<Integer> orderLineEntrSet = orderEntry.getOrderReleases().stream()
.flatMap(orderReleaseEntry ->
orderReleaseEntry.getOrderLines().stream())
.filter(orderLineEntry -> {
String s = orderLineEntry.getStatus();
return "PP".equals(s) || "PD".equals(s);
})
.map(e -> e.getId())
.collect(Collectors.toSet());
double[] totalAmount = { 0.0 };
double[] couponDiscount = { 0.0 };
orderLineEntryList.stream()
.flatMap(sre -> sre.getLineEntries().stream())
.filter(ole -> orderLineEntrySet.contains(ole.getOrderLineId())
.filter(ole -> !"PX".equals(ole.getStatusCode()))
.forEach(ole -> {
totalAmount[0] += ole.getFinalAmount();
if (ole.getCouponDiscount() != null)
couponDiscount[0] += ole.getCouponDiscount();
});
您可以通过使用 reduce 函数来避免使用对数组对象的引用。例如查看 Collectors.averagingDouble 是如何实现的。但我觉得这更复杂。
注意:这是 O(N),使用一组 ID 而不是使用匹配 ID 的列表,这将是 O(N^2)
List<T> intersect = list1.stream().filter(set1::contains).collect(Collectors.toList());
只要 T
是 String
、Integer
、Float
等,这就有效,其中 equals 和 HashCode 方法很简单。但是如果T
是一个自定义对象,我们需要实现HashCode & equals