使用Java8将列表型数据转为树形数据

博客展示了Java相关代码,但未给出具体代码内容。

代码如下:

import cn.hutool.core.collection.CollectionUtil;
import com.alibaba.fastjson.JSONObject;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import lombok.Data;
import lombok.experimental.Accessors;
import org.junit.Test;

import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class Demo {

	@Test
	public void test01() {
	    List<Node> nodes = Lists.newArrayList();
	    Node node = new Node();
	    node.setId(1).setName("root").setPid(0);
	    nodes.add(node);
	    node = new Node();
	    node.setId(2).setName("level1-1").setPid(1);
	    nodes.add(node);
	    node = new Node();
	    node.setId(3).setName("level1-2").setPid(1);
	    nodes.add(node);
	
	    node = new Node();
	    node.setId(4).setName("level2-1").setPid(2);
	    nodes.add(node);
	
	    node = new Node();
	    node.setId(5).setName("level2-1").setPid(2);
	    nodes.add(node);
	
	    Map<Integer, List<Node>> nodeMap = nodes.stream().collect(Collectors.groupingBy(Node::getPid));
	
	    Map<Integer, Node> nodeMap2 = nodes.stream().collect(Collectors.toMap(Node::getId, x -> x));
	    for (Integer pid : nodeMap.keySet()) {
	        List<Node> nodeList = nodeMap.get(pid);
	        Node n = nodeMap2.get(pid);
	        if (n != null && CollectionUtil.isNotEmpty(nodeList)) {
	            n.setChildren(nodeList);
	        }
	    }
	
	    List<Node> result =  nodes.stream().filter(x -> x.getPid() == 0).collect(Collectors.toList());
	    System.out.println(JSONObject.toJSONString(result));
	
	}
	
	@Data
	@Accessors(chain = true)
	public static class Node {
	    private int id;
	    private String name;
	    private int pid;
	    private List<Node> children;
	}
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值