java8 新特性Stream实现树状结构

当我们要对数据的父子关系进行树状结构整理时,一般我们会想到使用递归进行数据组装,但是这样写相对来说是比较麻烦的了,或者如果你的java架构是hibernate的时候可以直接通过注解实现,好了现在说下stream是如何实现树状结构的

本例子是以 CategoryId 和 pCategoryId 为父子关系

查出父子关系的所有数据 pidList
//以pid为Key进行分组存入Map
Map<Long,List> pidListMap = pidList.stream().collect(Collectors.groupingBy(CategoryListVO::getpCategoryId,LinkedHashMap::new,Collectors.toList()));
pidList.stream().forEach(item->{
item.setChildren(pidListMap.get(item.getCategoryId())==null?new ArrayList<>():pidListMap.get(item.getCategoryId()));
});
//取出顶层节点的对象,本例顶层节点的"PID"为0,注意是PID
// Object obj = JSONArray.toJSON(pidListMap.get(0l));
// String json = obj.toString();
// System.out.println(json);
pidListMap.get(0l)==null?new ArrayList<>():pidListMap.get(0l);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值