std::filesystem库在C++17中引入,提供跨平台文件和目录操作;2. 核心类型path支持路径处理,自动识别分隔符;3. 常用方法包括/=、+=、parent_path()、filename()等。

在C++17中,std::filesystem库被正式引入,提供了便捷的文件和目录操作接口。它封装了跨平台的路径处理、文件读写判断、目录遍历等功能,让开发者无需依赖系统API即可完成常见操作。
路径操作:std::filesystem::path
std::filesystem::path 是所有文件系统操作的基础类型,用于表示文件或目录路径,支持跨平台分隔符自动识别(如Windows用反斜杠,Linux用正斜杠)。
常用方法:-
append() 或 /=:添加路径段,例如
path /= "subdir" - concat() 或 +=:拼接字符串到路径末尾
- parent_path():获取父目录路径
- filename():获取文件名部分
- extension():获取扩展名
- is_absolute():判断是否为绝对路径
示例:
std::filesystem::path p = "/home/user/test.txt"; std::cout << p.parent_path() << "\n"; // 输出: "/home/user" std::cout << p.filename() << "\n"; // 输出: "test.txt" std::cout << p.extension() << "\n"; // 输出: ".txt"
检查文件状态与属性
使用 std::filesystem::status() 和相关函数可判断文件类型和权限。
立即学习“C++免费学习笔记(深入)”;
常用函数:- exists(path):路径是否存在
- is_regular_file(path):是否是普通文件
- is_directory(path):是否是目录
- is_empty(path):文件或目录是否为空
- file_size(path):获取文件大小(字节),仅对普通文件有效
- last_write_time(path):获取最后修改时间
示例:
std::filesystem::path p = "example.txt";
if (std::filesystem::exists(p)) {
if (std::filesystem::is_regular_file(p)) {
std::cout << "大小: " << std::filesystem::file_size(p) << " 字节\n";
}
}
创建、删除与重命名文件/目录
标准库提供了直接的操作函数,简化了常见任务。
主要函数:- create_directory(path):创建单个目录(需确保父目录存在)
- create_directories(path):递归创建多级目录
- remove(path):删除文件或空目录
- remove_all(path):递归删除目录及其内容
- rename(old_path, new_path):重命名或移动文件/目录
示例:
// 创建多级目录
std::filesystem::create_directories("data/logs/temp");
// 删除整个目录树
std::filesystem::remove_all("temp_backup");
// 重命名文件
std::filesystem::rename("old.txt", "new.txt");
遍历目录内容
使用 std::filesystem::directory_iterator 可逐项遍历目录中的条目。
若需递归遍历子目录,使用 recursive_directory_iterator。
// 遍历当前目录
for (const auto& entry : std::filesystem::directory_iterator(".")) {
std::cout << entry.path() << " ";
if (entry.is_directory()) std::cout << "[DIR]";
else if (entry.is_regular_file()) std::cout << "[FILE]";
std::cout << "\n";
}
// 递归遍历
for (const auto& entry : std::filesystem::recursive_directory_iterator("data")) {
std::cout << entry.path() << "\n";
}
基本上就这些。std::filesystem 提供了简洁统一的接口,避免了平台差异带来的复杂性,适合大多数文件管理需求。只要编译器支持C++17(如GCC 8+、Clang 7+、MSVC 2017以上),就可以直接使用。注意包含头文件:#include ,并在代码中使用 std::filesystem 命名空间。











