在 go 中,管道是用于 goroutine 之间通信的 fifo 队列。创建一个管道:使用 make(chan t) 函数,其中 t 是管道中数据类型。发送数据:使用 ch

Go 中使用管道进行函数通信
在 Go 中,管道是一种轻量级的通信机制,它允许 goroutine(Go 协程)之间安全有效地交换数据。管道本质上是一个 FIFO(先进先出)队列,goroutine 可以通过管道发送和接收数据。
创建管道
立即学习“go语言免费学习笔记(深入)”;
管道使用 make(chan T) 函数创建,其中 T 是管道中承载的数据类型。以下示例创建了一个通道,该通道包含字符串类型的数据:
ch := make(chan string)
发送数据
家政服务平台系统包含家用电器安装清洗、搬家、家电维修、管道疏通、月嫂保姆、育儿陪护、上门开锁等多种服务项目,用户可以直接通过家政小程序咨询,在线预约服务类型,同时还设置有知识科普,给用户科普一些清洁保养小技巧,让用户能够足不出户就可以直接预约服务,方便又快捷。本项目使用微信小程序平台进行开发。使用腾讯专门的小程序云开发技术,云资源包含云函数,数据库,带宽,存储空间,定时器等,资源配额价格低廉,无需
要向管道发送数据,请使用 ch 语法,其中 ch 是要发送数据的管道,而 data 是要发送的值。
ch <- "Hello, World!"
接收数据
要从管道接收数据,请使用 语法,其中 ch 是要从中接收数据的管道。
message := <-ch
实战案例:并发文件读取
让我们创建一个使用管道并发的文件读取程序。该程序将从多个文件中读取数据并将其发送到管道,另一个 goroutine 将从管道接收数据并将其打印到控制台。
package main
import (
"bufio"
"fmt"
"io/ioutil"
"log"
"os"
)
func readFile(filePath string, ch chan string) {
file, err := os.Open(filePath)
if err != nil {
log.Fatal(err)
}
defer file.Close()
scanner := bufio.NewScanner(file)
for scanner.Scan() {
ch <- scanner.Text()
}
}
func main() {
ch := make(chan string)
// 从多个文件中读取数据
files := []string{"file1.txt", "file2.txt", "file3.txt"}
for _, file := range files {
go readFile(file, ch)
}
// 从管道接收并打印数据
for {
message := <-ch
if message == "" {
break
}
fmt.Println(message)
}
}在这个例子中,我们创建了一个管道 ch,它将保存从文件中读取的行。三个 goroutine 并发地从不同的文件中读取数据并将其发送到管道。另一个 goroutine 从管道接收数据并将其打印到控制台中。









