Go 的 io.Reader 和 io.Writer 是流式处理核心接口,通过 io.Pipe、io.TeeReader、io.MultiReader 和 io.Copy 等组合可构建灵活低内存管道:Pipe 实现 goroutine 间双向流,TeeReader 边读边写(如计算哈希),MultiReader 顺序合并多个 Reader,自定义 Reader/Writer 可扩展能力(如进度回调)。
Go 语言的 io.Reader 和 io.Writer 是流式处理的核心接口,它们不关心数据来源或去向,只专注“读”和“写”的契约。利用它们的组合能力(如 io.Pipe、io.MultiReader、io.TeeReader、io.Copy 等),可以构建灵活、低内存占用的数据管道。
io.Pipe() 返回一对连接的 io.Reader 和 io.Writer:往 writer 写入的数据可立即被 reader 读出,适合在 goroutine 间传递流式数据,避免内存堆积。
示例:将大文件逐块压缩并写入网络,不全量加载到内存:
pr, pw := io.Pipe() defer pr.Close()// 启动压缩 goroutine:从 pr 读,压缩后写入响应 go func() { defer pw.Close() gz := gzip.NewWriter(pw) _, err := io.Copy(gz, pr) // pr 流入 → gz 压缩 → pw 流出 gz.Close() if err != nil { log.Printf("compress error: %v", err) } }()
// 主流程:打开文件,拷贝到 pw(即流入管道) file, _ := os.Open("huge.log") defer file.Close() io.Copy(pw, file) // file → pw → pr → gz → ...
io.TeeReader(r, w) 在读取 r 的同时,把读到的数据**原样写入** w(如日志文件、hash 计算器、监控计数器)。它不缓冲,不改变原始流行为,适合审计、校验、埋点等场景。
示例:上传文件时实时计算 SHA256 并保存原始内容:
file, _ := os.Open("upload.bin")
hasher := sha256.New()
tee := io.TeeReader(file, hasher) // 每次 Read 都同步写入 hasher
// 将 tee 流复制到目标存储(如磁盘或对象存储)
dst, _ := os.Create("saved.bin")
n, err := io.Copy(dst, tee)
fmt.Printf("copied %d bytes, hash: %x\n", n, hasher.Sum(nil))
io.MultiReader(rs...io.Reader) 把多个 reader 串成一个逻辑 reader,按顺序读完第一个再读第二个……适合拼接 header + body、多段配置、分片合并等。
示例:构造 HTTP 响应体(JSON header + CSV body):
header := strings.NewReader(`{"count":3,"format":"csv"}\n`)
body := strings.NewReader("name,age\nAlice,30\nBob,25\n")
combined := io.MultiReader(header, body)
http.ServeContent(w, r, "data.json", time.Now(), combined)
只要实现 Read([]byte) (int, error) 或 Write([]byte) (int, error),就能无缝接入标准管道。例如实现带进度回调的 Writer:
type ProgressWriter struct {
w io.Writer
total int64
written int64
onWrite func(int64, int64) // callback: current, total
}
func (pw *ProgressWriter) Write(p []byte) (n int, err error) {
n, err = pw.w.Write(p)
pw.written += int64(n)
pw.onWrite(pw.written, pw.total)
return
}
// 使用
pw := &ProgressWriter{w: os.Stdout, total: fileSize}
io.Copy(pw, src) // 实时打印进度
# js
# json
# go
# golang
# csv
# 内存占用
# Error
# int
# 接口
# 堆
# copy
# http
# 多个
# 流式
# 自定义
# 回调
# 流管
# 第一个
# 就能
# 第二个
# 不全
# 它不
相关文章:
建站VPS能否同时实现高效与安全翻墙?
,如何利用word制作宣传手册?
建站之星如何一键生成手机站?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
建站之星如何实现网站加密操作?
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
网站制作服务平台,有什么网站可以发布本地服务信息?
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
太原网站制作公司有哪些,网约车营运证查询官网?
实例解析Array和String方法
制作宣传网站的软件,小红书可以宣传网站吗?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
PHP 500报错的快速解决方法
javascript基本数据类型及类型检测常用方法小结
北京制作网站的公司,北京铁路集团官方网站?
建站之星如何助力网站排名飙升?揭秘高效技巧
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
如何注册花生壳免费域名并搭建个人网站?
h5网站制作工具有哪些,h5页面制作工具有哪些?
nginx修改上传文件大小限制的方法
红河网站制作公司,红河事业单位身份证如何上传?
如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?
如何在阿里云完成域名注册与建站?
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
高防服务器租用指南:配置选择与快速部署攻略
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
建站VPS选购需注意哪些关键参数?
如何实现建站之星域名转发设置?
如何通过商城免费建站系统源码自定义网站主题?
怀化网站制作公司,怀化新生儿上户网上办理流程?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
如何在阿里云ECS服务器部署织梦CMS网站?
建站之星伪静态规则如何正确配置?
如何快速查询域名建站关键信息?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
已有域名如何免费搭建网站?
如何用景安虚拟主机手机版绑定域名建站?
Swift中switch语句区间和元组模式匹配
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何高效生成建站之星成品网站源码?
家庭建站与云服务器建站,如何选择更优?
专业商城网站制作公司有哪些,pi商城官网是哪个?
宁波免费建站如何选择可靠模板与平台?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
建站之星如何助力企业快速打造五合一网站?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
如何做静态网页,sublimetext3.0制作静态网页?
建站VPS配置与SEO优化指南:关键词排名提升策略
如何通过虚拟机搭建网站?详细步骤解析
*请认真填写需求信息,我们会在24小时内与您取得联系。