io.Copy是Go中高效拷贝数据的核心方法,适用于文件复制,通过自动缓冲机制简化代码并提升性能。

io.Copy 是 Golang 中用于高效拷贝数据的核心方法之一,特别适合文件之间的复制操作。它定义在 io 包中,函数签名为:
func Copy(dst Writer, src Reader) (written int64, err error)
该函数会从源 src 读取数据并写入目标 dst,直到遇到 EOF 或发生错误。底层会自动使用固定大小的缓冲区(通常为 32KB),因此无需手动实现循环读写,性能高且代码简洁。
基本用法:使用 io.Copy 拷贝文件
下面是一个完整的示例,展示如何使用 io.Copy 实现文件拷贝:
立即学习“go语言免费学习笔记(深入)”;
package main
import (
"io"
"os"
)
func copyFile(src, dst string) error {
sourceFile, err := os.Open(src)
if err != nil {
return err
}
defer sourceFile.Close()
destinationFile, err := os.Create(dst)
if err != nil {
return err
}
defer destinationFile.Close()
_, err = io.Copy(destinationFile, sourceFile)
return err
}
func main() {
err := copyFile("source.txt", "copy.txt")
if err != nil {
panic(err)
}
}
这段代码完成了以下步骤:
- 使用 os.Open 打开源文件(只读)
- 使用 os.Create 创建目标文件(可写)
- 调用 io.Copy 将源内容写入目标
- 通过 defer 确保文件句柄正确关闭
优化建议:提升大文件拷贝效率
虽然 io.Copy 默认缓冲机制已经很高效,但在处理超大文件时,可以通过自定义缓冲区进一步优化性能。
使用 io.CopyBuffer 可以指定缓冲区大小:
buffer := make([]byte, 64*1024) // 64KB 缓冲区 _, err = io.CopyBuffer(destinationFile, sourceFile, buffer)
适当增大缓冲区(如 64KB 或 128KB)可以减少系统调用次数,提升吞吐量,尤其适用于 SSD 或高速磁盘环境。
注意事项与最佳实践
在实际使用中,注意以下几点以确保稳定性和兼容性:
- 始终使用 defer file.Close() 防止资源泄露
- 拷贝前检查源文件是否存在、是否有读写权限
- 目标路径的目录需存在,否则 Create 会失败
- 对于极大数据流,考虑结合 io.TeeReader 或进度监控
- 若需保留文件元信息(如权限、时间戳),io.Copy 不支持,需额外处理
例如,保留原始文件权限:
fileInfo, _ := sourceFile.Stat() os.Chmod(dst, fileInfo.Mode())基本上就这些。使用 io.Copy 进行文件拷贝简单、安全、高效,是 Go 中推荐的标准做法。










