0

0

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

尼克

尼克

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

|

792人浏览过

|

来源于php中文网

原创

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() << '
';
}
  • skip_existingoverwrite_existing 更安全,尤其对生产脚本
  • 不加任何选项时,若 dst.txt 已存在,会直接抛异常 "File exists"
  • 源路径必须是普通文件;若是符号链接,默认会解引用(即复制目标文件),如需复制链接本身,加 copy_options::copy_symlinks

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

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

立即学习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() << '
';
}
  • 不能只靠 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 —— 检查磁盘空间、预扫描大小、分块复制、校验哈希,这些都得自己补。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

1848

2023.10.19

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

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

614

2025.10.17

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

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

2356

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

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

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

763

2023.08.10

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

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

763

2023.08.10

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

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

1431

2023.07.26

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

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

1164

2023.07.27

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

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

精品课程

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

共94课时 | 10.8万人学习

C 教程
C 教程

共75课时 | 5.2万人学习

C++教程
C++教程

共115课时 | 20.9万人学习

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

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