牛骨文教育服务平台(让学习变的简单)

Go 并行通道Channel

Channel是连接并行协程(goroutine)的通道。你可以向一个通道写入数据然后从另外一个通道读取数据。

package main

import "fmt"

func main() {

	// 使用`make(chan 数据类型)`来创建一个Channel
	// Channel的类型就是它们所传递的数据的类型
	messages := make(chan string)

	// 使用`channel <-`语法来向一个Channel写入数据
	// 这里我们从一个新的协程向messages通道写入数据ping
	go func() { messages <- "ping" }()

	// 使用`<-channel`语法来从Channel读取数据
	// 这里我们从main函数所在的协程来读取刚刚写入
	// messages通道的数据
	msg := <-messages
	fmt.Println(msg)
}

运行结果

ping

当我们运行程序的时候,数据ping成功地从一个协程传递到了另外一个协程。
默认情况下,协程之间的通信是同步的,也就是说数据的发送端和接收端必须配对使用。Channel的这种特点使得我们可以不用在程序结尾添加额外的代码也能够获取协程发送端发来的信息。因为程序执行到msg:=<-messages的时候被阻塞了,直到获得发送端发来的信息才继续执行。