【167期】Java8 新特性:使用 Stream 流递归实现遍历树形结构
点击上方“Java精选”,选择“设为星标”
别问别人为什么,多问自己凭什么!
下方有惊喜留言必回,有问必答!
每天 08:35 更新文章,每天进步一点点...
可能平常会遇到一些需求,比如构建菜单,构建树形结构,数据库一般就使用父id来表示,为了降低数据库的查询压力,我们可以使用Java8中的Stream流一次性把数据查出来,然后通过流式处理,我们一起来看看,代码实现为了实现简单,就模拟查看数据库所有数据到List里面。
实体类:Menu.java
/**
* Menu
*
* @author lcry
*/
@Data
@Builder
public class Menu {
/**
* id
*/
public Integer id;
/**
* 名称
*/
public String name;
/**
* 父id ,根节点为0
*/
public Integer parentId;
/**
* 子节点信息
*/
public List<Menu> childList;
public Menu(Integer id, String name, Integer parentId) {
this.id = id;
this.name = name;
this.parentId = parentId;
}
public Menu(Integer id, String name, Integer parentId, List<Menu> childList) {
this.id = id;
this.name = name;
this.parentId = parentId;
this.childList = childList;
}
}
递归组装树形结构。推荐公众号Java精选,回复Java面试,获取面试题资料,支持在线随时随地刷题:
@Test
public void testtree(){
//模拟从数据库查询出来,公众号Java精选,有惊喜!
List<Menu> menus = Arrays.asList(
new Menu(1,"根节点",0),
new Menu(2,"子节点1",1),
new Menu(3,"子节点1.1",2),
new Menu(4,"子节点1.2",2),
new Menu(5,"根节点1.3",2),
new Menu(6,"根节点2",1),
new Menu(7,"根节点2.1",6),
new Menu(8,"根节点2.2",6),
new Menu(9,"根节点2.2.1",7),
new Menu(10,"根节点2.2.2",7),
new Menu(11,"根节点3",1),
new Menu(12,"根节点3.1",11)
);
//获取父节点
List<Menu> collect = menus.stream().filter(m -> m.getParentId() == 0).map(
(m) -> {
m.setChildList(getChildrens(m, menus));
return m;
}
).collect(Collectors.toList());
System.out.println("-------转json输出结果-------");
System.out.println(JSON.toJSON(collect));
}
/**
* 递归查询子节点
* @param root 根节点
* @param all 所有节点
* @return 根节点信息
*/
private List<Menu> getChildrens(Menu root, List<Menu> all) {
List<Menu> children = all.stream().filter(m -> {
return Objects.equals(m.getParentId(), root.getId());
}).map(
(m) -> {
m.setChildList(getChildrens(m, all));
return m;
}
).collect(Collectors.toList());
return children;
}
格式化打印结果:
版权声明:本文为CSDN博主「Lcry」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
https://blog.csdn.net/qq_19244927/article/details/106481777
3000+ 道面试题在线刷,最新、最全 Java 面试题!
【159期】面试官问:说说 MongoDB 批量操作与 MySQL 效率对比?
【160期】实习面试:为什么 Java 中 1000==1000 为 false,而 100==100 为 true?
【161期】MySQL 性能优化的 9 种姿势,面试再也不怕了!
【162期】面试官:请说说对 HashMap 及 LinkedHashMap 源码底层的深入理解(八股文)
【163期】MYSQL 中 SQL 语句三种去除重复数据的方法
【164期】面试官问:为什么生产环境中,建议禁用 Redis 的 keys 命令?
最近有很多人问,有没有读者交流群,想知道如何加入。加入方式很简单,有兴趣的同学,只需要点击下方卡片,回复“加群”,即可免费加入我们的高质量技术交流群!