375. Java IO API - 列出目录内容

文章目录

  • [375. Java IO API - 列出目录内容](#375. Java IO API - 列出目录内容)
      • [🚀 核心方法简介](#🚀 核心方法简介)
      • [✅ 基本示例:打印目录内容](#✅ 基本示例:打印目录内容)
      • [🧹 try-with-resources 的重要性](#🧹 try-with-resources 的重要性)
      • [🎯 输出路径的完整形式(绝对路径)](#🎯 输出路径的完整形式(绝对路径))
      • [🔍 过滤目录内容(按扩展名或模式筛选)](#🔍 过滤目录内容(按扩展名或模式筛选))
        • [示例:只列出 `.txt` 文件](#示例:只列出 .txt 文件)
      • [⚠️ 异常处理说明](#⚠️ 异常处理说明)
      • [📌 小结对比:常用目录操作方式](#📌 小结对比:常用目录操作方式)

375. Java IO API - 列出目录内容

Java NIO 中,如果你想查看一个目录中的所有文件、子目录、符号链接等条目,推荐使用 Files.newDirectoryStream() 方法。这是一种高效、可扩展的方式,适用于大规模目录遍历


🚀 核心方法简介

java 复制代码
DirectoryStream<Path> stream = Files.newDirectoryStream(Path dir);
  • 返回一个 DirectoryStream<Path>,该接口本身实现了 Iterable<Path>
  • 支持高效迭代目录内容,适合目录下条目较多的情况。
  • 推荐使用 try-with-resources 自动关闭资源。

✅ 基本示例:打印目录内容

java 复制代码
import java.nio.file.*;
import java.io.IOException;

public class ListDirContents {
    public static void main(String[] args) {
        Path dir = Paths.get("your-directory-path-here");

        try (DirectoryStream<Path> stream = Files.newDirectoryStream(dir)) {
            for (Path entry : stream) {
                System.out.println("Entry: " + entry.getFileName());
            }
        } catch (IOException | DirectoryIteratorException e) {
            System.err.println("Error reading directory: " + e.getMessage());
        }
    }
}

🧠 提示:

  • 使用 entry.getFileName() 获取文件名(而不是完整路径)。
  • 这是按目录中的顺序返回所有内容(包括隐藏文件、子目录、符号链接等)。

🧹 try-with-resources 的重要性

DirectoryStream 是一个可关闭资源,如果你不使用 try-with-resources,需要手动调用 stream.close(),否则可能导致资源泄露。

☕ 使用 Java 7+try-with-resources 可以确保在使用完毕后自动关闭流资源。


🎯 输出路径的完整形式(绝对路径)

你也可以输出完整路径,例如:

java 复制代码
System.out.println("Full path: " + entry.toAbsolutePath());

🔍 过滤目录内容(按扩展名或模式筛选)

你可以使用重载的 newDirectoryStream(Path dir, String glob) 方法对结果进行过滤。

示例:只列出 .txt 文件
java 复制代码
try (DirectoryStream<Path> stream = Files.newDirectoryStream(dir, "*.txt")) {
    for (Path entry : stream) {
        System.out.println("Text file: " + entry.getFileName());
    }
}

🧠 Glob 模式支持:

  • "*.java" 匹配所有 Java 文件
  • "*.*" 匹配包含扩展名的所有文件
  • "data-??.log" 匹配如 data-01.logdata-99.log

⚠️ 异常处理说明

  • IOException:创建目录流时可能抛出,例如路径无效、无权限访问。
  • DirectoryIteratorException :在迭代过程中 出现异常,会被封装成此异常类型。根本原因可以通过 getCause() 访问。
java 复制代码
} catch (DirectoryIteratorException e) {
    System.err.println("Iterate failed: " + e.getCause());
}

📌 小结对比:常用目录操作方式

操作目标 使用方法
列出所有文件和子目录 Files.newDirectoryStream()
仅列出特定扩展名的文件 Files.newDirectoryStream(dir, "*.txt")
自动关闭目录流资源 使用 try-with-resources
获取文件名 entry.getFileName()
获取完整路径 entry.toAbsolutePath()
捕获迭代异常 捕获 DirectoryIteratorException
相关推荐
石榴树下的七彩鱼1 小时前
图片去水印 API 详解:从单图到批量自动化去水印(附 Python/JS/PHP 完整教程)
python·自动化·图片处理·图片去水印·石榴智能·api教程
Dicky-_-zhang2 小时前
系统容量规划与压测实战:从1万到100万QPS的科学扩容
java·jvm
Highcharts.js7 小时前
倒置百分比堆叠面积图表示列详解|Highcharts大气成分图表代码
开发语言·信息可视化·highcharts·图表开发·面积图·图表示例·推叠图
Li emily8 小时前
解决了加密货币api多币种订阅时的数据乱序问题
人工智能·python·api·fastapi
csdn_aspnet8 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
Dicky-_-zhang8 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进
java·jvm
晨曦中的暮雨8 小时前
4.15腾讯 CSIG云服务产线 一面
java·开发语言
2301_781571428 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
存在morning8 小时前
【GO语言开发实践】二 GO 并发快速上手
大数据·开发语言·golang
fake_ss1988 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法