0

0

多路复用多个 Go Channel 到单个 Channel

碧海醫心

碧海醫心

发布时间:2025-09-06 18:45:16

|

916人浏览过

|

来源于php中文网

原创

多路复用多个 go channel 到单个 channel

本文介绍了如何将多个只读的 Go Channel 中的数据合并到一个单独的只写 Channel 中,并在所有输入 Channel 关闭后关闭输出 Channel。通过使用 sync.WaitGroup 来同步 Goroutine,确保所有输入 Channel 的数据都被处理完毕后才关闭输出 Channel,避免数据丢失,提供了一种高效且安全的 Channel 多路复用方案。

并发编程中,经常会遇到需要将多个 Channel 的数据汇聚到一个 Channel 的场景,例如,从多个数据源读取数据,然后统一处理。Go 语言的 Channel 提供了强大的并发通信机制,结合 Goroutine 和 select 语句可以实现 Channel 的多路复用。然而,当需要处理的 Channel 数量不确定时,手动编写 select 语句会变得非常繁琐。本文将介绍一种利用 sync.WaitGroup 实现任意数量 Channel 多路复用的方法。

使用 sync.WaitGroup 实现 Channel 多路复用

以下代码展示了如何使用 sync.WaitGroup 将多个

package main

import (
    "fmt"
    "sync"
)

func combine(inputs []<-chan int, output chan<- int) {
    var group sync.WaitGroup

    // 启动 Goroutine 处理每个输入 Channel
    for i := range inputs {
        group.Add(1)
        go func(input <-chan int) {
            defer group.Done() // 确保 Goroutine 退出时调用 Done()

            for val := range input {
                output <- val // 将输入 Channel 的数据发送到输出 Channel
            }
            // 输入 Channel 关闭后,该 Goroutine 会自动退出
        }(inputs[i])
    }

    // 启动 Goroutine 等待所有输入 Channel 处理完毕
    go func() {
        group.Wait()       // 等待所有 Goroutine 调用 Done()
        close(output) // 关闭输出 Channel
    }()
}

func main() {
    // 创建多个输入 Channel
    numChannels := 3
    inputChannels := make([]<-chan int, numChannels)
    for i := 0; i < numChannels; i++ {
        ch := make(chan int)
        inputChannels[i] = ch
        go func(index int, ch chan int) {
            for j := 0; j < 5; j++ {
                ch <- index*10 + j
            }
            close(ch)
        }(i, ch)
    }

    // 创建输出 Channel
    outputChannel := make(chan int)

    // 多路复用输入 Channel 到输出 Channel
    combine(inputChannels, outputChannel)

    // 从输出 Channel 读取数据并打印
    for val := range outputChannel {
        fmt.Println(val)
    }

    fmt.Println("Done!")
}

代码解释:

  1. combine 函数:
    • 接收一个 []
    • 使用 sync.WaitGroup 来同步 Goroutine 的完成状态。
    • 为每个输入 Channel 启动一个 Goroutine,负责从该 Channel 读取数据并发送到输出 Channel。
    • 每个 Goroutine 在退出前调用 group.Done(),表示该 Channel 的数据已处理完毕。
    • 启动一个单独的 Goroutine,等待所有输入 Channel 的 Goroutine 完成后关闭输出 Channel。
  2. main 函数:
    • 创建多个输入 Channel,每个 Channel 模拟一个数据源。
    • 创建输出 Channel,用于接收所有输入 Channel 的数据。
    • 调用 combine 函数将多个输入 Channel 多路复用到输出 Channel。
    • 从输出 Channel 读取数据并打印,直到输出 Channel 关闭。

注意事项:

方舟订单管理系统
方舟订单管理系统

系统开发由二当家的编写,代码完全开源,可自行修改源码,欢迎使用! 1、网站采用php语言开发,更安全、稳定、无漏洞、防注入、防丢单。 2、记录订单来路,客户IP记录及分析,订单数据统计 3、订单邮件提醒、手机短信提醒,让您第一时间追踪订单,大大提升了发货效率,提高订单成交率。 4、多种支付方式,包含:货到付款、支付宝接口、网银支付,可设置在线支付的折扣比率。 5、模板样式多样化,一个订单放到多个网

下载
  • 必须在每个处理输入 Channel 的 Goroutine 中使用 defer group.Done() 确保 Goroutine 退出时调用 Done(),避免 group.Wait() 永久阻塞。
  • 输出 Channel 必须在所有输入 Channel 处理完毕后才能关闭,否则可能会丢失数据。
  • 输入 Channel 必须是只读 Channel (

总结:

通过使用 sync.WaitGroup,我们可以轻松地将任意数量的 Channel 多路复用到一个 Channel 中,并在所有输入 Channel 关闭后安全地关闭输出 Channel。这种方法避免了手动编写复杂的 select 语句,提高了代码的可维护性和可读性。该方案适用于各种需要将多个数据源的数据汇聚到一起进行处理的场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

483

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

545

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

113

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

200

2025.08.29

go语言 数组和切片
go语言 数组和切片

本专题整合了go语言数组和切片的区别与含义,阅读专题下面的文章了解更多详细内容。

46

2025.09.03

Golang channel原理
Golang channel原理

本专题整合了Golang channel通信相关介绍,阅读专题下面的文章了解更多详细内容。

248

2025.11.14

golang channel相关教程
golang channel相关教程

本专题整合了golang处理channel相关教程,阅读专题下面的文章了解更多详细内容。

344

2025.11.17

php环境变量如何设置
php环境变量如何设置

本合集详细讲解PHP环境变量的设置方法,涵盖Windows、Linux及常见服务器环境配置技巧,助你快速掌握环境变量的正确配置。阅读专题下面的文章了解更多详细内容。

0

2026.01.31

php图片如何上传
php图片如何上传

本合集涵盖PHP图片上传的核心方法、安全处理及常见问题解决方案,适合初学者与进阶开发者。阅读专题下面的文章了解更多详细内容。

2

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 4.4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号