
在C++中拷贝一个文件,可以通过多种方式实现。最常见的是使用标准库中的 fstream 读取源文件内容,并写入目标文件。也可以借助操作系统提供的API(如Windows或POSIX接口)进行更高效的复制。下面介绍几种实用且跨平台兼容性较好的方法。
使用ifstream和ofstream进行文件复制
这是最基础、最常用的C++文件复制方法,利用输入输出文件流逐字节或按块读写数据。
示例代码:#include#include bool copyFile(const std::string& src, const std::string& dest) { std::ifstream source(src, std::ios::binary); if (!source.is_open()) { return false; }
std::ofstream destination(dest, std::ios::binary); if (!destination.is_open()) { source.close(); return false; } destination << source.rdbuf(); source.close(); destination.close(); return true;}
说明:
- 使用 std::ios::binary 模式打开文件,确保二进制文件也能正确复制。
- source.rdbuf() 获取源文件的缓冲区,直接通过流插入操作符写入目标文件,效率较高。按缓冲区大小分块读写
对于大文件,一次性读取整个rdbuf可能占用较多内存。可以采用固定大小的缓冲区循环读取,降低内存消耗。
示例代码:#include#include bool copyFileChunk(const std::string& src, const std::string& dest, size_t bufferSize = 4096) { std::ifstream source(src, std::ios::binary); std::ofstream destination(dest, std::ios::binary);
if (!source || !destination) { if (source) source.close(); if (destination) destination.close(); return false; } std::vectorbuffer(bufferSize); while (source.read(buffer.data(), bufferSize)) { destination.write(buffer.data(), bufferSize); } // 写入最后剩余的数据 destination.write(buffer.data(), source.gcount()); source.close(); destination.close(); return true; }
优点:
- 控制内存使用量,适合处理大型文件。
- 可自定义缓冲区大小以平衡性能与资源占用。使用C++17的filesystem库(推荐)
如果编译器支持C++17及以上版本,可以直接使用
库中的 copy_file 函数,简洁高效。 立即学习“C++免费学习笔记(深入)”;
示例代码:#include#include namespace fs = std::filesystem;
bool copyUsingFilesystem(const std::string& src, const std::string& dest) { try { fs::copy_file(src, dest, fs::copy_options::overwrite_existing); return true; } catch (const fs::filesystem_error& e) { std::cerr << "Copy failed: " << e.what() << '\n'; return false; } }
特点:
- 接口简单,一行代码完成复制。
- 支持覆盖选项、权限保留等高级功能。
- 需要启用C++17:编译时添加 -std=c++17(g++/clang)或对应设置(MSVC)。跨平台注意事项
上述方法在Windows和Linux上均能正常工作,但需注意以下几点:
- 文件路径应使用正斜杠 / 或双反斜杠 \\ 避免转义问题。
- 确保程序对源文件有读权限,对目标路径有写权限。
- 目标文件若已存在,某些方法会失败,可先删除或使用覆盖参数。基本上就这些常用方法。小项目可用fstream手动复制,现代C++建议优先使用filesystem库,简洁安全。根据编译环境选择合适方案即可。











