前言
在Go语言中,管道(Channel)是一种非常强大的机制,用于在协程(Goroutine)之间同步和传递数据。一个管道(通道)并不局限于只在两个协程之间使用。通道可以在任意数量的协程之间进行通信。多个协程可以同时向一个通道发送数据,也可以有多个协程从同一个通道接收数据。
一、创建管道
ch := make(chan int)
创建一个无缓存的管道。
二、建立发送协程
// 多个发送协程
go func() {
for i := 1; i <= 5; i++ {
ch <- i
}
}()
go func() {
for i := 6; i <= 10; i++ {
ch <- i
}
}()
三、创建接收协程
// 多个接收协程
go func() {
for num := range ch {
fmt.Println("Receiver 1 got:", num)
}
}()
go func() {
for num := range ch {
fmt.Println("Receiver 2 got:", num)
}
}()
四、测试函数
package main
import (
"fmt"
"time"
)
func main() {
ch := make(chan int)
// 多个发送协程
go func() {
for i := 1; i <= 5; i++ {
ch <- i
}
}()
go func() {
for i := 6; i <= 10; i++ {
ch <- i
}
}()
// 多个接收协程
go func() {
for num := range ch {
fmt.Println("Receiver 1 got:", num)
}
}()
go func() {
for num := range ch {
fmt.Println("Receiver 2 got:", num)
}
}()
time.Sleep(time.Second)
}
通道改为无缓冲的,写入操作会交替进行,确保先写入的数据被读取后,另一个协程才能继续写入。