全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

如何使用Golang io.Reader和io.Writer组合实现数据管道_流式处理示例

Go 的 io.Reader 和 io.Writer 是流式处理核心接口,通过 io.Pipe、io.TeeReader、io.MultiReader 和 io.Copy 等组合可构建灵活低内存管道:Pipe 实现 goroutine 间双向流,TeeReader 边读边写(如计算哈希),MultiReader 顺序合并多个 Reader,自定义 Reader/Writer 可扩展能力(如进度回调)。

Go 语言的 io.Readerio.Writer 是流式处理的核心接口,它们不关心数据来源或去向,只专注“读”和“写”的契约。利用它们的组合能力(如 io.Pipeio.MultiReaderio.TeeReaderio.Copy 等),可以构建灵活、低内存占用的数据管道。

用 io.Pipe 构建双向流管道

io.Pipe() 返回一对连接的 io.Readerio.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 实现“边读边记录”管道

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 组合多个 Reader 成单一流

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)

用 io.Copy + 自定义 Reader/Writer 扩展管道能力

只要实现 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小时内与您取得联系。