java 中怎么生成一个树形结构
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,java 中怎么生成一个树形结构,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。树形结构是非常常见的数据结构,生成树形结构
千家信息网最后更新 2025年01月31日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中 MaptreeMap = 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安全错误
数据库的锁怎样保障安全
ffmpeg软件开发详细教程
钢铁之师2无法连接服务器
大华存储服务器温度过高怎么处理
山西吕梁软件开发公司
数据库发展的三个历史阶段
网络安全基础第5版答案
数据库云端技术
易名服务器
软件开发企业做账
商道融绿esg数据库怎么找
废弃电脑改阵列服务器
网络技术部主要职责
网络安全七百字作文
几个好用的数据库语句
打印服务器的管理地址
服务器设置管理员权限设置
支付网络技术公司
通过服务器管理教室局域网
工控网络安全防护能力现状
比特牛交易所找不到服务器
紫外可见光光谱数据库
华为软件开发学啥专业
金方达生产的服务器怎么样
软件开发中哪个岗位比较好
如何建立账号管理服务器
ache服务器讲解
潮州智能建模软件开发
360浏览器代理服务器设置
完美cs服务器连接失败
会议室网络安全