统计文件夹总大小需递归遍历子目录与文件并累加普通文件长度;可用File类递归实现,注意处理空目录、权限异常、隐藏文件、符号链接循环及性能优化;推荐Java 8+的Files.walk()流式方案。

要统计一个文件夹的总大小,核心思路是递归遍历所有子目录和文件,累加每个普通文件的长度。Java 中 File 类虽已过时(推荐用 java.nio.file),但在简单工具开发中仍直观易用,配合递归逻辑即可快速实现。
使用 File + 递归遍历目录结构
File 对象可通过 listFiles() 获取子项数组,对每个子项判断:如果是文件,直接加 size;如果是目录,则递归调用自身。注意空目录或权限不足时返回值需合理处理(如跳过或记为 0)。
- 递归终止条件:当前
File是普通文件(isFile() == true) - 递归入口:对每个子
File调用同一统计方法 - 异常处理:捕获
SecurityException防止因无访问权限中断整个统计
避免常见陷阱:隐藏文件、符号链接与循环引用
默认 listFiles() 不过滤系统隐藏文件(如 macOS 的 .DS_Store 或 Windows 的 Thumbs.db),若需排除,可先用 file.isHidden() 判断。更关键的是符号链接(symlink)——File 默认不识别其是否指向父目录,可能引发无限递归。简单方案是限制递归深度(如最大 32 层),或维护已访问路径 Set 做去重(需规范化路径,用 getCanonicalPath())。
提升性能与用户体验的小技巧
大目录下频繁 IO 可能导致卡顿。可在递归中加入轻量级进度提示(如每处理 100 个文件打印当前累计大小),或用 SwingWorker 异步执行防界面冻结。另外,返回结果建议统一为字节(long),再按需格式化为 KB/MB/GB(除以 1024 或 1024²),避免 float/double 引入精度误差。
立即学习“Java免费学习笔记(深入)”;
替代方案:用 Files.walk() 实现更简洁的流式统计
Java 8+ 推荐用 Files.walk() 替代手写递归。它返回 Stream,天然支持函数式操作:
Files.walk(path).filter(Files::isRegularFile).mapToLong(p -> { try { return Files.size(p); } catch (IOException e) { return 0; } }).sum();- 自动处理符号链接(默认不跟随)、支持并发(
parallel()),且异常可控 - 注意:
walk()默认不限制深度,大目录建议加.limit(n)或用Files.walk(path, maxDepth)










