io.Copy 是 Go 中统一处理任意 io.Reader/io.Writer 类型数据复制的核心工具,支持文件、网络、内存流等场景,自动分块读写、需检查错误并关闭资源。
在 Go 中,io.Copy 是最常用、最简洁的数据复制工具,它能统一处理文件、网络连接、内存缓冲区等任意实现了 io.Reader 和 io.Writer 接口的类型。只要源支持读、目标支持写,就能直接复制,无需关心底层是磁盘 I/O 还是 TCP 流。
这是最直观的场景。打开源文件(io.R)和目标文件(
eaderio.Writer),传给 io.Copy 即可:
os.Open 打开源文件,os.Create 或 os.OpenFile 创建/打开目标文件io.Copy 内部自动分块读写(默认 32KB 缓冲),避免一次性加载大文件到内存常见于下载场景。HTTP 响应体(resp.Body)是 io.ReadCloser,文件句柄是 io.WriteCloser,天然适配:
resp.Body 和本地文件句柄传给 io.Copy
resp.Body.Close() 和文件 .Close()(或用 defer)ioutil.ReadAll 读全部内容再写,会吃光内存;io.Copy 流式处理更安全当需要在内存中中转或模拟流式处理时,bytes.Buffer 和 io.Pipe 是好搭档:
bytes.Buffer 同时实现 io.Reader 和 io.Writer,适合小数据缓存或测试io.Pipe() 返回配对的 io.Reader 和 io.Writer,常用于协程间流式通信(如一个 goroutine 写,另一个读)io.Copy(pipeWriter, src),主线程从 pipeReader 读取,实现解耦io.Copy 本身不暴露缓冲区或进度,但可通过包装实现:
io.CopyBuffer(dst, src, make([]byte, 64*1024)) 指定缓冲区大小(如 64KB),提升大文件性能io.Reader(如实现 Read(p []byte) 方法,在每次读完后触发回调)io.TeeReader 在读取时同步写入日志或计算哈希,不影响主流程不复杂但容易忽略:始终关闭资源、检查错误、避免内存泄漏。用好 io.Copy,就能写出清晰、高效、符合 Go 风格的流式 I/O 代码。