0

0

c++中如何使用std::filesystem::copy_c++文件与目录复制方法【详解】

尼克

尼克

发布时间:2026-01-15 16:03:57

|

792人浏览过

|

来源于php中文网

原创

c++kquote>std::filesystem::copy默认不递归、不覆盖、不创建父目录,复制目录需显式指定recursive选项,否则抛出filesystem_error;复制文件应搭配skip_existing等选项并预处理路径。

c++中如何使用std::filesystem::copy_c++文件与目录复制方法【详解】

直接说结论:std::filesystem::copy 能复制文件和目录,但行为高度依赖 copy_options 参数组合,不加选项默认只复制单个文件(不递归、不覆盖、不创建父目录),多数人第一次用都会失败。

为什么 std::filesystem::copy 复制目录时没反应?

因为默认行为不递归 —— 它把目录当普通文件处理,遇到目录就抛出 std::filesystem::filesystem_error,错误信息通常是 "Is a directory""Operation not supported"

  • 必须显式传入 std::filesystem::copy_options::recursive 才能进入子目录
  • 若目标目录已存在,还需 std::filesystem::copy_options::skip_existingstd::filesystem::copy_options::overwrite_existing,否则会因路径冲突失败
  • 目标父目录不存在时,copy 不自动创建,得提前调用 std::filesystem::create_directories

复制单个文件的最小安全写法

避免覆盖误操作,同时确保目标路径可写:

namespace fs = std::filesystem;
try {
    fs::copy("src.txt", "dst.txt",
        fs::copy_options::skip_existing);
} catch (const fs::filesystem_error& e) {
    // 处理权限不足、只读文件、目标在只读文件系统等
    std::cerr << "Copy failed: " << e.what() << '\n';
}
  • skip_existingoverwrite_existing 更安全,尤其对生产脚本
  • 不加任何选项时,若 dst.txt 已存在,会直接抛异常 "File exists"
  • 源路径必须是普通文件;若是符号链接,默认会解引用(即复制目标文件),如需复制链接本身,加 copy_options::copy_symlinks

完整复制目录(含子目录与文件)

这是最常出错的场景:既要递归,又要处理目标存在性、又要建父目录:

Open Voice OS
Open Voice OS

OpenVoiceOS是一个社区驱动的开源语音AI平台

下载

立即学习C++免费学习笔记(深入)”;

namespace fs = std::filesystem;
fs::path src = "my_folder";
fs::path dst = "backup/my_folder";

// 1. 确保目标父目录存在
fs::create_directories(dst.parent_path());

// 2. 复制(递归 + 覆盖已存在项)
try {
    fs::copy(src, dst,
        fs::copy_options::recursive |
        fs::copy_options::overwrite_existing);
} catch (const fs::filesystem_error& e) {
    std::cerr << "Directory copy failed: " << e.what() << '\n';
}
  • 不能只靠 recursive —— 如果 backup/ 不存在,copy 会失败,不会自动创建 backup
  • overwrite_existingskip_existing 互斥,不能同时设
  • 若源目录含符号链接,默认仍解引用;要保留链接结构,额外或上 copy_symlinks
  • Windows 下注意长路径限制(\\?\ 前缀不被 std::filesystem 自动处理,需自行转换)

性能与跨平台差异提醒

std::filesystem::copy 是同步阻塞调用,大文件或深层目录会卡住线程;且各标准库实现行为略有不同:

  • libstdc++(GCC)在 Linux 上实际调用 copy_file_rangesendfile,小文件也走 read/write
  • MSVC STL 在 Windows 上用 CopyFileExW,支持进度回调(但 C++ 标准接口不暴露)
  • macOS 的 libc++ 使用 copyfile(3),对 ACL 和扩展属性支持更完整
  • 所有实现都不保证原子性:复制中途崩溃,可能留下部分文件,无回滚机制

真正需要健壮备份逻辑时,别只靠一层 copy —— 检查磁盘空间、预扫描大小、分块复制、校验哈希,这些都得自己补。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1018

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

62

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

402

2025.12.29

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

576

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1099

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

790

2023.08.01

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.7万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号