
在C++17中,std::filesystem 被正式引入标准库,提供了便捷的文件系统操作功能。其中,递归遍历目录是常见需求,比如查找所有子文件、统计目录大小或清理临时文件。使用 std::filesystem::recursive_directory_iterator 可以轻松实现这一功能。
包含头文件与命名空间
要使用文件系统功能,需包含头文件并引入命名空间:
#include#include iostream>
注意:某些编译器(如GCC)需要启用 C++17 并链接 -lstdc++fs(旧版本),新版本通常不再需要手动链接。
使用 recursive_directory_iterator 遍历目录
std::filesystem::recursive_directory_iterator 会自动进入子目录,深度优先遍历整个目录树。以下是一个基本示例:
立即学习“C++免费学习笔记(深入)”;
std::string path = "/your/directory/path";for (const auto& entry : std::filesystem::recursive_directory_iterator(path)) {
std::cout }
这段代码会打印出指定路径下所有文件和子目录的完整路径。
过滤文件类型与执行操作
实际应用中,通常只关心特定类型的文件。可以通过 entry.is_regular_file() 或检查扩展名来过滤:
for (const auto& entry : std::filesystem::recursive_directory_iterator(path)) {if (entry.is_regular_file()) {
if (entry.path().extension() == ".txt") {
std::cout }
}
}
你也可以判断是否为目录:entry.is_directory(),用于跳过或特别处理文件夹。
异常处理与路径有效性
目录遍历时可能遇到权限不足或路径不存在等问题,建议用 try-catch 包裹:
try {for (const auto& entry : std::filesystem::recursive_directory_iterator(path)) {
std::cout }
} catch (const std::filesystem::filesystem_error& ex) {
std::cerr accessing path: " }
这能避免程序因个别错误路径而崩溃。
基本上就这些。配合 lambda 或函数对象,还能将遍历逻辑封装成通用工具。std::filesystem 让 C++ 的文件操作变得现代且直观。








