在项目中很容易遇到那种需要取并集或者交集的情况。

如果按照传统的方式,使用for循环嵌套for循环来操作,也可以实现。但是代码看起来没有那么优雅。

Java8提供了Stream的操作。

例如简单的递归查找。

根据当前的分类找到相对应的所有子级对象。

如果使用传统for循环。一般的操作方式

 

//查出所有的对象,然后根据对象进行判断操作
List<Ojbect> list = new Array<>();
list = service.queryList()
//此处的Object泛指一个对象。
for(Object obj:list){
//TODO
//查找所有parentId=当前ID的数据,再判断是否还存在下级
//。。。。。。
}

  

Stream的操作方式比较简单。

如下

//1、将所有的List数据进行筛选,然后根据筛选出来的数据进行并集操作
 
List<Entity> allEntities = service.querylist();
 
//2、筛选下级
List<Entity> sencondEntities = allEntities.parallelStream().filter(s -> s.getParentCid()==id)).collect(Collectors.toList());
 
//3、根据下级筛选下下级
 List<Entity> thirdleveEntities =  allEntities.stream().filter(a -> sencondEntities.stream().map(Entity::getId).collect(Collectors.toList()).contains(a.getParentId())).collect(Collectors.toList());

  

这样就可以把所有的下级和下下级都筛选出来了。

说明下,这个只是对于有限下级的操作,对于不确定的和数据集合大的,走递归可能还是比较方便一些。这个因为数据总量小于500;层级只有3级,所以选择了这样的操作。其实很多时候代码是为业务服务的,如果业务有限,没必要考虑通盘的扩展,毕竟性能和扩展性一样重要。

后记,整篇文章有用的代码只有这一句,其他都是凑数的。看懂了这行,其他的都是白搭的。

allEntities.stream().filter(a -> sencondEntities.stream().map(Entity::getId).collect(Collectors.toList()).contains(a.getParentId())).collect(Collectors.toList())