java 中怎么生成一个树形结构
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,java 中怎么生成一个树形结构,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。树形结构是非常常见的数据结构,生成树形结构
千家信息网最后更新 2025年12月02日java 中怎么生成一个树形结构
java 中怎么生成一个树形结构,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
树形结构是非常常见的数据结构,生成树形结构的方法比较常见的有递归,for循环,不管使用什么方法,如果能很好地利用内存来合理地添加树节点,则能极大提高效率
测试代码如下:
public class TestTree { public static void main(String[] args) { C3p0Jdbc jdbc = new C3p0Jdbc(); String sql = "SELECT code value,up_code upCode,name label,level FROM test_table WHERE level < 4 ORDER BY level"; JSONArray arr = jdbc.query(sql); // 先将数据循环放入新建的map中 Map treeMap = new HashMap<>(); int length = arr.size(); long t1 = System.currentTimeMillis(); for (int i = 0; i < length; i++) { String key = arr.getJSONObject(i).getString("value"); treeMap.put(key, arr.getJSONObject(i)); } long t2 = System.currentTimeMillis(); System.out.println("循环用时:" + (t2 - t1) + "ms"); JSONArray new_tree = new JSONArray(); // 再使用双层for循环,根据判断条件,将符合条件的节点数据添加到树形结构中 for (int i = 0; i < length; i++) { JSONObject parent = arr.getJSONObject(i); String key = parent.getString("value"); int level = parent.getIntValue("level"); // 这是唯一一处需要 new 对象的地方 JSONArray children = new JSONArray(); for (int j = 0; j < length; j++) { JSONObject child = arr.getJSONObject(j); String childKey = child.getString("value"); String upCode = child.getString("upCode"); if (upCode.equals(key)) { children.add(treeMap.get(childKey)); } } parent.put("children", children); if (level == 1) { new_tree.add(parent); } } long t3 = System.currentTimeMillis(); System.out.println("第二次遍历用时:" + (t3 - t2) + "ms"); System.out.println("全过程用时:" + (t3 - t1) + "ms"); } } 在for循环中务必要减少new 对象的次数,New 对象是很耗时的操作,不仅仅是 new 对象会很耗时,其它操作比如将一个 object 转为 jsonarray 或 json 也会很耗时,因为这种操作修改了内存中对象的引用地址,测试代码中最优势的地方就是将所有的对象都加载到map中,在new_tree.add(parent)的操作时是直接将parent对象的内存引用地址添加到了new_tree中,所以效率非常快,我的测试数据是3227条国内的省市区县数据,全过程用时在600~850 ms之间 效果如图:
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
对象
结构
数据
循环
树形
内存
测试
生成
代码
全过程
地址
地方
效率
方法
条件
节点
帮助
清楚
不仅仅
之间
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库主从选举
求生药抗服务器代码
服务器后端
架设linux服务器
保障财政网络安全
x86服务器的raid卡通用吗
cts网络安全大赛
中移动网络技术要求
深圳启视点网络技术
谷歌服务器密码保存不了
美领互联网科技招聘
加强网络安全监督检查的措施
美女相亲男生是网络安全员
天津星际ipfs服务器虚拟主机
超级支付互联网科技有限公司
深岩银河搜不到朋友服务器
手写签批软件开发
网络安全的签到题怎么做
游戏数据库脚本
陕西缘赛纳网络技术有限公司
服务器基岩版
adhoc 网络技术
个人网络安全保险保单
数据库分类汇报
大陆访问香港服务器
华为p8登录微信显示链接服务器
山西精英网络技术服务哪家好
马来西亚服务器
北京像素软件开发的游戏
陕西缘赛纳网络技术有限公司