网站首页 > java教程 正文
背景
之前写过一个文章 Java递归将List数据转换为Tree结构数据_填坑指南 用的是递归的方法,后来在今日头条上也发布了,评论区以为大佬给了我一些指点(如下图),我看了之后恍然大悟,相对于使用递归,此方法只需写一个方法,方法中两个循环,而使用递归的话,需要写三个方法,还要用递归,使用递归不仅内存开销大,性能也不行。
- 大佬提供的代码
具体实现
/**
* 对象List转为Tree树形结构
* @param entityList 传进来的泛型List
* @param parentFieldName 父级字段名称
* @return
*/
public final List<Map<String, Object>> listToTree1(List<T> entityList, String parentFieldName){
//返回的map Tree树形结构
List<Map<String, Object>> treeMap = new ArrayList<>();
//将传进的参数entityList转为MapList
List<Map<String, Object>> listMap = JSON.parseObject(JSON.toJSONString(entityList), List.class);
//声明一个map用来存listMap中的对象,key为对象id,value为对象本身
Map<String, Map<String, Object>> entityMap = new Hashtable<>();
//循环listMap把map对象put到entityMap中去
listMap.forEach(map -> entityMap.put(map.get("id").toString(), map));
//循环listMap进行Tree树形结构组装
listMap.forEach(map -> {
//获取map的pid
Object pid = map.get(parentFieldName);
if (pid == null){ //判断pid是否为空,为空说明是最顶级,直接add到返回的treeMap中去
treeMap.add(map);
} else { //如果pid不为空
//根据当前map的pid获取上级 parentMap
Map<String, Object> parentMap = entityMap.get(pid);
if (parentMap == null){ //如果parentMap为空,则说明当前map没有父级,当前map就是顶级
treeMap.add(map);
} else { //如果parentMap不为空,则当前map为parentMap的子级
//取出parentMap的所有子级的List集合
List<Map<String, Object>> children = (List<Map<String, Object>>)parentMap.get("children");
if (children == null){ //判断子级集合是否为空,为空则新创建List
children = new ArrayList<>();
parentMap.put("children", children);
}
//把当前map对象add到parentMap的子级List中去
children.add(map);
/**
* 因为parentMap是从entityMap中get出来的,
* 而entityMap中的value又是来自于listMap对象,
* 所以parentMap和entityMap中的value的地址都是指向listMap中的对象,
* 所以parentMap的children和entityMap中的value的children改变时,都会改变listMap中的对象,
* 这里涉及到了地址、指针,就不多说了。
*/
}
}
});
return treeMap;
}
总结
因为parentMap是从entityMap中get出来的,而entityMap中的value又是来自于listMap对象,所以parentMap和entityMap中的value的地址都是指向listMap中的对象,所以parentMap的children和entityMap中的value的children改变时,都会改变listMap中的对象,这里涉及到了地址、指针,就不多说了。
这里再次感谢@托尼老师学编程提供的思路,大家有什么可以优化的想法请在评论区留言,谢谢。
猜你喜欢
- 2024-10-03 SpringBoot中如何根据JSON数据生成一个动态对象?
- 2024-10-03 边玩手机边学Java----Java基础之Map
- 2024-10-03 Java Stream API:优雅地操作Map(java map stream filter)
- 2024-10-03 聊聊Mybatis的初始化之Mapper.xml映射文件的解析
- 2024-10-03 MapStruct 使用教程, 万字详解(mapstruct enum)
- 2024-10-03 看似简单,在JAVA中如何将一个Object转换成Array
- 2024-10-03 java8函数式Map操作也太强大了吧,1次就帮我省了10多行代码
- 2024-10-03 map的一个骚操作!你学废了么?#互联网
- 2024-10-03 轻松搞定!用JavaScript将列表转换为Map
- 2024-10-03 告别 BeanUtils,拥抱 MapStruct:高效 Java 对象映射的经典之选
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)