List转成树结构

/**
 * List转成树结构
 */
public static List<Menu> buildTree(List<Menu> lisy) {
    //先选出非顶级的节点
    List<Menu> list = lisy.stream().filter(node -> node.getParentId() != 0L).collect(Collectors.toList());
    //将这些非顶级节点的数据按pid进行分组
    Map<Long, List<Menu>> sub = list.stream().collect(Collectors.groupingBy(Menu::getParentId));
    //循环设置对应的子节点(根据id = pid)
    lisy.forEach(node -> node.setChildren(sub.get(node.getObjectId())));
    //过滤掉父节点数据
    return lisy.stream().filter(node -> node.getParentId() == 0L).collect(Collectors.toList());
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值