C++17引入std::filesystem库,提供跨平台文件目录操作。需包含头文件并启用C++17,常用操作包括路径存在性判断、类型识别、目录创建删除、遍历、属性获取及文件重命名复制,推荐使用fs::path处理路径,注意异常与权限问题。

在C++17中,std::filesystem库被正式引入,提供了一套现代化、跨平台的方式来操作文件和目录。相比传统的C风格或boost::filesystem方式,它更简洁安全。下面介绍如何使用该库进行常见文件与目录操作。
启用std::filesystem
要使用std::filesystem,需确保编译器支持C++17及以上标准。 在代码中包含头文件:#include
namespace fs = std::filesystem;
检查文件或目录是否存在
最基础的操作是判断路径是否存在:
fs::path p{"example.txt"};
if (fs::exists(p)) {
std::cout
}
if (fs::exists("data/config")) { ... }
立即学习“C++免费学习笔记(深入)”;
判断路径类型(文件/目录)
可进一步区分是普通文件还是目录:-
fs::is_regular_file(path):判断是否为普通文件 -
fs::is_directory(path):判断是否为目录 -
fs::is_empty(path):判断文件或目录是否为空
if (fs::is_directory("my_folder")) {
std::cout
}
创建与删除目录
创建单个目录:fs::create_directory("new_folder");
fs::create_directories("a/b/c");
fs::remove("empty_folder");
fs::remove_all("folder_with_files");
遍历目录内容
使用 fs::directory_iterator 遍历目录中的每一项:
for (const auto& entry : fs::directory_iterator("my_dir")) {
std::cout
}
for (const auto& entry : fs::recursive_directory_iterator("root")) {
if (fs::is_regular_file(entry)) {
std::cout
}
}
获取文件属性
可读取文件大小、最后修改时间等信息:-
fs::file_size(path):返回文件字节数 -
fs::last_write_time(path):返回最后修改时间(std::filesystem::file_time_type)
if (fs::is_regular_file("test.txt")) {
std::cout
}
重命名与复制文件
重命名或移动文件/目录:fs::rename("old_name.txt", "new_name.txt");
fs::copy("source.txt", "backup.txt");
fs::copy("a.txt", "b.txt", fs::copy_options::overwrite_existing);
实用技巧与注意事项
- 路径可使用正斜杠 "/" 或反斜杠 "\\",库会自动处理跨平台兼容
- 推荐使用 fs::path 对象管理路径,支持拼接:
fs::path p = "dir" / "sub" / "file.txt"; - 某些操作可能抛出 filesystem_error 异常,生产环境建议用 try-catch 包裹
- Windows下需注意权限问题,尤其是系统目录或正在使用的文件











