理解和重构目录结构:Java 中的父子关系管理
理解和重构目录结构:Java 中的父子关系管理
- 一、前言
- 1. 问题背景
- 2. 目录项结构
- 3. 实现重构逻辑
- 4. 示例代码
- 5. 结果与输出
- 二、总结
好的,我们将目录结构调整为使用中文数字表示的标题。以下是重新组织后的内容:
一、前言
在软件开发中,目录结构的管理和组织是一个常见的问题,尤其是在处理复杂的文件和数据时。如何有效地将打乱的目录结构重构为层级清晰的树状结构是一个重要的技能。本文将通过示例代码和解释,介绍如何在 Java 中实现这一功能,特别是处理具有父子关系的目录。
1. 问题背景
在许多应用程序中,目录(如文件系统、数据分类等)常常以列表的形式存在,每个目录项通常包含自身的 ID 和其父目录的 ID。这种结构虽然简单,但在存储和查询时可能会变得混乱,尤其是当目录项的顺序打乱时。我们需要一种方法来将其重组为清晰的树状结构,使得每个目录可以方便地访问其子目录。
2. 目录项结构
首先,我们需要定义一个目录项的数据结构。以 Java 为例,可以使用一个简单的类 CatalogVO
来表示每个目录项。这个类包含以下属性:
- id: 目录项的唯一标识符
- parentId: 该目录项的父目录的 ID
- subData: 一个列表,包含该目录项的所有子目录
class CatalogVO {private String id;private String parentId;private List<CatalogVO> subData = new ArrayList<>();// Getters and Setterspublic String getId() {return id;}public void setId(String id) {this.id = id;}public String getParentId() {return parentId;}public void setParentId(String parentId) {this.parentId = parentId;}public List<CatalogVO> getSubData() {return subData;}
}
3. 实现重构逻辑
接下来,我们需要编写一个方法来重构目录项的父子关系。这个方法将遍历所有目录项,将它们组织成一个树状结构。具体步骤如下:
- 构建 Map:使用一个 HashMap 将目录项的 ID 映射到
CatalogVO
对象,方便后续查找。 - 建立父子关系:再次遍历目录项,根据
parentId
属性,将子目录添加到其父目录的subData
列表中。 - 返回根目录:最终返回所有没有父目录的目录项,作为树的根节点。
public class CatalogOrganizer {public List<CatalogVO> groupCatalog(List<CatalogVO> catalogVOList) {Map<String, CatalogVO> catalogMap = new HashMap<>();List<CatalogVO> rootList = new ArrayList<>();// 第一遍遍历,构建 Mapfor (CatalogVO catalog : catalogVOList) {catalogMap.put(catalog.getId(), catalog);}// 第二遍遍历,建立父子关系for (CatalogVO catalog : catalogVOList) {if (catalog.getParentId() == null || "0".equals(catalog.getParentId())) {// 如果没有父目录,添加到根目录列表rootList.add(catalog);} else {// 如果有父目录,找到父目录并添加到其子目录列表CatalogVO parentCatalog = catalogMap.get(catalog.getParentId());if (parentCatalog != null) {parentCatalog.getSubData().add(catalog);}}}return rootList; // 返回所有根目录}
}
4. 示例代码
在 main
方法中,我们可以创建一些示例目录项,并调用 groupCatalog
方法来测试我们的实现。
public static void main(String[] args) {List<CatalogVO> catalogVOList = new ArrayList<>();// 示例数据CatalogVO parentCatalog = new CatalogVO();parentCatalog.setId("f8d410a48035fb23eeb50d5b255c6d5e");parentCatalog.setParentId("0"); // 根目录CatalogVO childCatalog = new CatalogVO();childCatalog.setId("13404145216f6881e1d3cf10944cc2b9");childCatalog.setParentId("f8d410a48035fb23eeb50d5b255c6d5e"); // 指向父目录CatalogVO anotherChild = new CatalogVO();anotherChild.setId("anotherChildId");anotherChild.setParentId("f8d410a48035fb23eeb50d5b255c6d5e"); // 指向同一父目录catalogVOList.add(childCatalog);catalogVOList.add(anotherChild);catalogVOList.add(parentCatalog);// 调用方法CatalogOrganizer organizer = new CatalogOrganizer();List<CatalogVO> organizedCatalog = organizer.groupCatalog(catalogVOList);// 输出结果for (CatalogVO catalog : organizedCatalog) {System.out.println("根目录 ID: " + catalog.getId() + ", 子目录数量: " + catalog.getSubData().size());for (CatalogVO subCatalog : catalog.getSubData()) {System.out.println(" 子目录 ID: " + subCatalog.getId());}}
}
5. 结果与输出
运行上述代码后,输出将显示每个根目录及其子目录的数量和 ID。这验证了我们的实现可以正确处理打乱的目录结构,并重新构建为清晰的层级关系。
二、总结
在这篇文章中,我们讨论了如何在 Java 中处理和重构目录结构,尤其是在目录项的顺序可能被打乱的情况下。通过构建父子关系并将其组织成树状结构,我们可以更有效地管理和访问目录数据。这种方法不仅适用于文件系统,也适用于任何需要层级数据组织的场景。希望这篇文章能够帮助你更好地理解目录结构的管理,并在你的项目中应用这种思路。
相关文章:

理解和重构目录结构:Java 中的父子关系管理
理解和重构目录结构:Java 中的父子关系管理 一、前言1. 问题背景2. 目录项结构3. 实现重构逻辑4. 示例代码5. 结果与输出 二、总结 好的,我们将目录结构调整为使用中文数字表示的标题。以下是重新组织后的内容: 一、前言 在软件开发中&…...

ES6面试题:(第一天)
目录 1.var,let,const的区别 2.说说你对数组的解构和对象的解构的理解? 3.ES6的新语法 4.Map对象和Set对象的区别 5.Set实现数组去重 1.var,let,const的区别 使用 var 声明的变量,其作用域为全局作用域或者为所在的函数内局部作用域,且存在变量提升…...

【ChatGPT】什么是ChatGPT:基础介绍与使用场景
什么是ChatGPT:基础介绍与使用场景 在当今科技快速发展的时代,人工智能工具正逐步融入我们生活的方方面面。你是否曾在编写报告时陷入思路停滞?或者在客户服务中焦急等待响应?这些问题,随着 ChatGPT 的出现࿰…...

工业自动化为什么依赖光耦隔离器 --- 腾恩科技
光耦合器隔离器在工业自动化中必不可少,可确保信号传输,同时保护敏感电子设备和人员免受高压影响。选择合适的光耦合器隔离器取决于对操作环境和隔离要求的了解。本文将重点介绍在为工业应用选择光耦合器隔离器时需要考虑的关键因素。 光耦合器隔离器在工…...

Linux环境下Jmeter执行压测脚本
Linux环境下Jmeter执行压测脚本 前提官网下载Jmeter执行脚本 前提 注意:Jmeter的运行依赖Java环境 官网下载Jmeter 1、下载链接:https://dlcdn.apache.org//jmeter/binaries/apache-jmeter-5.6.3.zip 2、解压 unzip apache-jmeter-5.6.3.zip 执行脚本…...

PROFINET开发或EtherNet/IP开发嵌入式板有用于工业称重秤
这是一个真实案例,不过客户选择不透露其品牌名称。稳联技术的嵌入式解决方案助力工业称重设备制造商连接至任意工业网络。多网络连接使得称重设备能够轻松接入不同的控制系统,进而加快产品的上市时间。 我们找到了稳联技术的解决方案。他们成熟的技术与专…...

OracleT5-2 Solaris11安装
1、Solaris11安装 在光驱中插入Solaris11的光盘后,在ok提示中boot cdrom {0} ok boot cdrom NOTICE: Entering OpenBoot. NOTICE: Fetching Guest MD from HV. NOTICE: Starting additional cpus. NOTICE: Initializing LDC services. NOTICE: Probing PCI devices. N…...

详解 JuiceFS 在多云架构下的数据同步与一致性
随着大模型流行,GPU 算力资源正变得日益稀缺,传统的“算力跟着存储跑”的策略需要转变为“存储跟着算力跑”。为了确保数据一致性和管理的便捷性,企业通常在特定地区的公有云上选择对象存储作为所有模型数据的集中存储点。当进行计算任务调度…...

赛氪贡献突出获评优秀合作伙伴,第十九届环境友好科技竞赛落幕
2024年10月19日,第十九届全国环境友好科技竞赛终审答辩会在同济大学顺利举行,标志着这一环境领域顶级学科竞赛的又一盛事圆满落幕。本次竞赛由清华大学、同济大学、西安建筑科技大学及中国环境科学学会共同主办,吸引了全国各高校相关专业学生…...

GrowingIO埋点(前端)
GrowingIO埋点(前端) 一、CDN集成SDK 1、初始化 当用户加载页面的时候,会异步加载 WebJS SDK,不会影响到用户的加载速度,所以一般建议把这段代码加入到 <head></head> 中的最下面,这样能…...

MySQL-15.DQL-排序查询
一.DQL-排序查询 -- 排序查询 -- 1.根据入职时间,对员工进行升序排序 select * from tb_emp order by entrydate asc ;-- 2.根据入职时间,对员工进行降序排序 select * from tb_emp order by entrydate desc ;-- 3.根据 入职时间 对公司员工进行 升序排序…...

SpringBoot中大量数据导出方案:使用EasyExcel并行导出多个excel文件并压缩zip后下载
文章目录 前言一、控制器层代码二、服务层代码三、代码亮点分析 前言 SpringBoot的同步excel导出方式中,服务会阻塞直到Excel文件生成完毕,如果导出数据很多时,效率低体验差。有效的方案是将导出数据拆分后利用CompletableFuture,…...

黑马软件测试第一篇_数据库
说明: 数据库是专门用来存储数据的软件 注意: 对于测试工作而言, 如果项目页面没有实现, 但是我们又想要校验数据,则可以直接通过查询数据库实现 关系: 具体存在的商品录入后 -> 产生对应的数据(存到数据库中) -> 最后会被加载到项目页面中 数据库的分类 分类: 1> 关…...

第十六届蓝桥杯嵌入式组准备
最近我看很多人都在准备蓝桥杯的比赛了,这里我给大家整理一下历届真题或模拟题的讲解与源码 蓝桥杯嵌入式第十二届省赛真题二 蓝桥杯嵌入式第十三届省赛真题一 蓝桥杯嵌入式第十三届省赛真题二 蓝桥杯嵌入式第十四届省赛真题 蓝桥杯嵌入式第十四届模拟考试一 蓝…...

城乡供水信息化系统如何建设?
城乡供水信息化建设是一个综合性的过程,旨在通过现代信息技术提升农村供水系统的管理效率和服务质量。这一过程包含以下关键内容: 一、信息化基础设施建设 感知层建设:在农村饮水工程的关键部位,如水源地、水厂、供水管网等&#…...

【Petri网导论学习笔记】Petri网导论入门学习(七) —— 1.5 并发与冲突
导航 1.5 并发与冲突1.5.1 并发定义 1.14定义 1.15 1.5.2 冲突定义 1.17 1.5.3 一般Petri网系统中的并发与冲突定义 1.18一般网系统中无冲撞概念阻塞(有容量函数K的P/T系统,类似于冲撞)一般Petri网中并发与冲突共存情况 1.5 并发与冲突 Petr…...

MongoDB常用语句
1.只统计记录总数: let result await CorrectionRecordModel.countDocuments(db);2.数组遍历,循环体中可以有调用异步函数: for(let item of result2){if(item && Tool.checkNotEmptString(item.auth_id) && (item.status …...

自动创作PPT 利用提示词和大模型自动创建ppt
背景 ppt创作可以分为3个步骤:1.大纲撰写;2.内容填充;3.ppt实现。我前几天用十分钟的时间做了一个ppt,主讲大模型测评。这里给大家分享一下我的创作过程。 关于步骤1和步骤2,最近发现一个非常好的提示词,…...

二分类评价指标AUROC和AUPR
文章目录 一、AUROC(Area Under the Receiver Operating Characteristic Curve)二、AUPR(Area Under the Precision-Recall Curve)三、区别3.1 案例3.2 如何选择? 在分类任务中, AUROC(受试者工…...

雅迪控股营收、净利润和毛利下滑:销量大幅减少,屡屡抽查不合格
《港湾商业观察》廖紫雯 日前,雅迪集团控股有限公司(以下简称:雅迪控股,01585.HK)发布业绩报告,披露2024年上半年营收净利双下滑等情况,在业绩承压的情况下,雅迪控股遭多家券商下调…...

【网络安全】记一次漏洞挖掘
Spring Cloud Data Flow 热点漏洞详细分析 环境搭建 2.10.0 - 2.11.2版本都可以,这里下的2.11.2 源码下载https://github.com/spring-cloud/spring-cloud-dataflow/tree/v2.11.2 在src/docker-compose里面是有docker文件的,使用docker即可 最近是爆出…...

Redis遇到Hash冲突怎么办?
这是小伙伴之前遇到的一个面试题,感觉也是一个经典八股,和大伙分享下。 一 什么是 Hash 冲突 Hash 冲突,也称为 Hash 碰撞,是指不同的关键字通过 Hash 函数计算得到了相同的 Hash 地址。 Hash 冲突在 Hash 表中是不可避免的&am…...

React综合指南(四)
61、描述React事件处理。 为了解决跨浏览器兼容性问题,React中的事件处理程序将传递SyntheticEvent实例,该实例是React跨浏览器本机事件的跨浏览器包装器。这些综合事件具有与您惯用的本机事件相同的界面,除了它们在所有浏览器中的工作方式相…...

Spring集成Redisson及存取几种基本类型数据
目录 一.什么是Redisson 二.为什么要使用Redisson 三.Spring集成Redisson 1.添加依赖 2.添加配置信息 3.添加redisson配置类 四.Redisson存取各种类型数据 1.字符串(String类型) 存储 获取 2.object对象类型 1.实体类信息 2.存储 3.获取 3.List集合类型 第一种…...

Maplibre-gl\Mapbox-gl改造支持对矢量瓦片加密
Maplibre-gl是Mapbox-gl剔除自带地图服务之后的一个分支,代码很相似。Maplibre-gl\Mapbox-gl使用的pbf格式的矢量瓦片,数据量小,渲染效果好。但也存在着信息泄露的风险。但如果想使用这个开发框架的前端渲染效果,还必须要使用这个格式。最近研究了一下如何对矢量瓦片进行加…...

【功能安全】技术安全概念TSC
目录 01 TSC定义 02 TSC注意事项 03 TSC案例 📖 推荐阅读 01 TSC定义 所处位置 TSC:Technical safety concept技术安全概念 TSR:Technical safety requirement技术安全需求 在系统开发阶段属于安全活动4-6 系统层产品开发示例 TSC目的...

Spark数据源的读取与写入、自定义函数
1. 数据源的读取与写入 1.1 数据读取 读文件 read.jsonread.csv csv文件由两个部分组成:头部数据(也就是字段数据)、行数据。 read.orc 读数据库 read.jdbc(jdbc连接地址,table‘表名’,properties{‘user’用户名,‘password’密码,‘driv…...

LeetCode 每日一题 2024/10/14-2024/10/20
记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 10/14 887. 鸡蛋掉落10/15 3200. 三角形的最大高度10/16 3194. 最小元素和最大元素的最小平均值10/17 3193. 统计逆序对的数目10/18 3191. 使二进制数组全部等于 1 的最少操…...

接口测试(六)jmeter——参数化(配置元件 --> 用户定义的变量)
一、jmeter——参数化(配置元件 --> 用户定义的变量) 注:示例仅供参考 1. 参数化格式:${变量名} 2. 配置元件:用户定义的变量 3. 添加【用户定义的变量】,【线程组】–>【添加】–>【配置元件】–…...

【学习笔记】网络流
背景 马上ICPC了,很惊奇的发现自己没整理网络流的板子。 最大流 dinic 这里选用的是二分图最大匹配的板子:飞行员配对方案问题 #include<bits/stdc.h> #define int long long using namespace std; const int N1e67,inf1e18; struct E {int to…...