Go语言io包核心是io.Reader和io.Writer接口,提供统一流数据处理方式。1. Read(p []byte)从源读取数据,返回字节数和错误,遇末尾返回io.EOF;2. Write(p []byte)将数据写入目标,返回写入字节数和错误;3. io.Copy(dst Writer, src Reader)实现高效数据传输,内置32KB缓冲区,适用于文件、网络等场景;4. io.LimitReader限制读取字节数,防内存溢出;5. io.TeeReader在读取时同步写入另一目标,用于日志记录;6. io.MultiReader串联多个Reader顺序读取;7. io.Pipe创建同步管道,用于goroutine通信;8. 与os、net、bytes包结合,如http.Request.Body为io.ReadCloser,可直接用于io.Copy或json解码;9. bytes.Buffer实现Reader和Writer接口,作内存缓冲区。掌握这些接口与函数,可高效处理各类流式操作。

Go语言的io包是处理流数据的核心工具,适用于文件、网络、内存等各种输入输出场景。它定义了统一的接口,让不同数据源的操作方式保持一致,提升代码复用性和可读性。
理解io.Reader和io.Writer接口
io包的核心是两个基础接口:io.Reader 和 io.Writer。几乎所有流操作都基于它们。
io.Reader 的 Read(p []byte) 方法从数据源读取数据填充字节切片,返回读取字节数和错误。当读到末尾时,通常返回 io.EOF。
io.Writer 的 Write(p []byte) 方法将字节切片写入目标,返回写入字节数和错误。
立即进入“豆包AI人工智官网入口”;
立即学习“豆包AI人工智能在线问答入口”;
例如,从标准输入读取并写入标准输出:
buf := make([]byte, 1024)<br>for {<br> n, err := os.Stdin.Read(buf)<br> if err != nil && err != io.EOF {<br> log.Fatal(err)<br> }<br> if n == 0 {<br> break<br> }<br> os.Stdout.Write(buf[:n])<br>}
使用io.Copy高效传输数据
io.Copy(dst Writer, src Reader) 是最常用的函数之一,自动完成从Reader到Writer的数据复制,无需手动管理缓冲区。
它可以用于文件复制、HTTP响应写入、管道传输等场景。
比如复制文件:
src, _ := os.Open("input.txt")<br>defer src.Close()<br>dst, _ := os.Create("output.txt")<br>defer dst.Close()<br>io.Copy(dst, src)
这个函数内部使用32KB缓冲区,性能好且代码简洁。

豆包旗下AI学习应用
26
查看详情
组合使用io.LimitReader、io.TeeReader等工具
io包提供多个包装器函数,可以控制或监听数据流。
-
io.LimitReader(r Reader, n int64)限制最多读取n字节,适合防止内存溢出 -
io.TeeReader(r Reader, w Writer)在读取的同时将数据写入另一个目标,常用于日志记录 -
io.MultiReader(readers... Reader)将多个Reader串联成一个,按顺序读取 -
io.Pipe()创建同步管道,适合goroutine间通信
示例:只读取前100字节
limitedReader := io.LimitReader(file, 100)<br>io.Copy(os.Stdout, limitedReader)
结合其他包处理实际场景
io包常与os、net、bytes等包配合使用。
处理HTTP请求体时,http.Request.Body 是 io.ReadCloser,可以直接传给 io.Copy 或 json.NewDecoder。
在内存中操作时,bytes.Buffer 实现了 Reader 和 Writer 接口,适合作为临时缓冲区。
例如将JSON数据从请求写入文件:
var data struct{ Name string }<br>json.NewDecoder(req.Body).Decode(&data)<br>f, _ := os.Create("data.json")<br>json.NewEncoder(f).Encode(data)
基本上就这些。掌握io.Reader/Writer模型和常用辅助函数,就能灵活处理各种流式数据,写出简洁高效的Go代码。
大家都在看:
使用D3.js实现下拉菜单驱动的数据更新
使用 D3.js 实现下拉菜单联动更新图表
使用 D3.js 实现下拉菜单联动更新可视化图表
使用 D3.js 实现基于下拉菜单的动态数据更新
































暂无评论内容