使用 Java 8 个流用于 类 的层次结构

Using Java 8 Streams for hiearchy of classes

finalList= resultList.stream()
    . filter(nestedDo -> nestedDo.getAttrib8() == 'S' &&
            nestedDo.getFirstChildList().stream()
            .filter(c -> 
                    ("ST2".equals(c.getAttrib18()) || 
                     "ST3".equals(c.getAttrib18()) || 
                     "ST4".equals(c.getAttrib18()) 
                                                       &&
                         c.getGrandChildList() != null &&
                         c.getGrandChildList().stream()
                            .filter(gc -> 
                            date.after(gc.getAttrib19()) &&
                            date.before(gc.getAttrib43())
                            )
                            .findAny().isPresent())
                            )
                            .findAny().isPresent())
                            .collect(Collectors.toList());    

NestedCustomerDO50 是一个 class,由 NestedFirstChildDO50 继承,由 NestedGrandChildDO50 继承。每个 class 包含子列表 class(即 NestedCustomerDO50 包含 NestedFirstChildDO50 列表,NestedFirstChildDO50 包含 NestedGrandChildDO50 列表)。每个class包含50个属性(attrib1-atrib50)。

resultList 和 finalList 是 NestedCustomerDO 类型对象的列表。

getFirstChildList() returns NestedFirstChildDO50 类型对象的数组列表 getGrandChildList() returns NestedGrandtChildDO50

类型对象的数组列表

这里finalList包含基于所有级别过滤的过滤结果。但是,如果 resultList 根据第二级和第三级的过滤给出结果(非空),我想将 resultList 作为 finalList。因此,每当第二级和第三级过滤 returns 结果时,我想获得具有完整子列表的父列表。

例如:如果 NestedCustomerDO50 保存客户详细信息,NestedFirstChildDO50 保存地址详细信息,NestedGrandtChildDO50 保存城市详细信息,当我们通过上面的代码搜索时,我们只得到指定的过滤结果,但我想要所有客户详细信息,包括所有地址(不是指定的过滤后的地址)。

如果对问题有任何疑问,请添加评论。

你的描述和你的代码一样神秘,但据我了解,你只想知道是否有任何匹配,如果有,则使用整个原始列表和过滤后的(然后为空)列表。

这是学习 anyMatch 的正确点,它不仅可以解决您的任务,还可以简化您的内部条件,因为您可以将 .filter(element->condition).findAny().isPresent() 替换为 .anyMatch(element->condition)

List<?> finalList = resultList.stream()
  .anyMatch(nestedDo -> nestedDo.getAttrib8() == 'S' &&
    nestedDo.getFirstChildList().stream().anyMatch(c -> 
          "ST2".equals(c.getAttrib18())
       || "ST3".equals(c.getAttrib18())
       || "ST4".equals(c.getAttrib18()) 
          && c.getGrandChildList()!=null
          && c.getGrandChildList().stream().anyMatch(gc ->
              date.after(gc.getAttrib19()) && date.before(gc.getAttrib43()))
  ))? resultList: Collections.emptyList();

请注意,尽管大括号的放置对我来说很可疑,但我保留了最内层条件的逻辑与您的问题完全相同。