可以,但需注意它不递归复制目录且不自动创建父目录;单文件拷贝需显式调用create_directories()并指定overwrite_existing选项。

std::filesystem::copy 能直接替代系统命令吗?
可以,但要注意它默认不递归复制目录,也不自动创建缺失的父目录。它的行为更接近底层文件操作原语,不是 cp -r 的完整等价物。
- 若源是文件、目标是不存在的路径 → 成功复制
- 若源是文件、目标是已存在的文件 → 默认报错(
std::filesystem::filesystem_error) - 若源是目录、目标不存在 → 报错,除非显式加
copy_options::recursive - 目标父目录不存在时 → 总是失败,需提前用
create_directories()创建
最简安全的单文件拷贝写法
必须处理异常,并显式指定覆盖策略。以下代码能覆盖目标文件,且自动创建目标所在目录:
try {
std::filesystem::create_directories(std::filesystem::path("dst/").parent_path());
std::filesystem::copy("src.txt", "dst.txt",
std::filesystem::copy_options::overwrite_existing);
} catch (const std::filesystem::filesystem_error& e) {
// 例如:权限不足、路径太长、设备满等
std::cerr << "copy failed: " << e.what() << "\n";
}
-
create_directories()只创建末级目录及其所有缺失的祖先目录 -
overwrite_existing是关键,否则目标存在时抛出异常 - 不加该选项时,可用
exists("dst.txt")预判再决定是否删旧文件,但有竞态风险
复制整个目录树的注意事项
递归复制不是默认行为,漏掉 copy_options::recursive 会导致只拷贝空目录。
- 必须组合使用:
copy_options::recursive | copy_options::overwrite_existing - 若目标目录已存在,
recursive会尝试合并内容(类似rsync -r),不是“清空再覆写” - 符号链接默认被解引用(即拷贝指向的文件),如需保留链接,加
copy_options::copy_symlinks - 硬链接默认不保留(新文件独立 inode),无法用此 API 复制硬链接关系
示例:
立即学习“C++免费学习笔记(深入)”;
std::filesystem::copy("src_dir", "dst_dir",
std::filesystem::copy_options::recursive |
std::filesystem::copy_options::overwrite_existing);
Windows 下路径分隔符和权限问题
Windows 上反斜杠 \ 在 C++ 字符串中需转义,建议统一用正斜杠或 std::filesystem::path 构造:
- 错误写法:
"C:\data\file.txt"→\d和\f是非法转义 - 正确写法:
R"(C:\data\file.txt)"或"C:/data/file.txt"或std::filesystem::path("C:") / "data" / "file.txt" - 即使有管理员权限,NTFS 的 ACL 或只读属性也可能导致
copy失败(错误码常为ACCESS_DENIED) - 目标路径含 Unicode 字符时无问题(
std::filesystem原生支持 UTF-8 / UTF-16)
真正容易被忽略的是:跨分区复制大文件时,std::filesystem::copy 内部仍是“读+写”而非系统级的快速移动(如 Windows 的 CopyFileEx with COPY_FILE_COPY_SYMLINK)。性能敏感场景应考虑调用平台 API 或分块流式拷贝。











