概述

倡议先浏览 goroutine 大节。

Go 箴言: 不要通过共享内存来通信,而要通过通信来共享内存。

goroutine 是 Go 程序并发执行的实体,channel (通道) 则是它们之间的连贯,用于多个 goroutine 之间相互通信。
通道能够让一个 goroutine 发送特定类型值到另一个 goroutine,每一个通道能够发送数据类型称为通道的 元素类型

阻塞通道与非阻塞通道

通过关键字 chan + 数据类型 来表明通道数据类型,调用 make() 函数来初始化一个通道。
make() 函数的第二个参数为通道长度,如果未指定或指定为 0,则该通道为非缓存通道 (阻塞通道),
否则该通道为缓存通道 (非阻塞通道)。

阻塞通道

图片起源: https://stackoverflow.com/que...

例子

ch := make(chan string) // 非缓冲通道ch := make(chan string, 0) // 非缓冲通道ch := make(chan string, 10) // 缓冲通道, 容量为 10

3 种操作

发送

无缓冲通道下面的发送操作将会阻塞,直到另一个 goroutine 在对应的通道下面实现接管操作,两个 goroutine 才能够继续执行。

语法规定

通道变量 <- 数据# 例如: 将变量 x 发送到通道 chch <- x 

接管

无缓冲通道下面的接管操作将会阻塞,直到另一个 goroutine 在对应的通道下面实现发送操作,两个 goroutine 才能够继续执行。

语法规定

<- 通道变量# 例如: 从通道 ch 接管一个值,并且抛弃<-ch ````

接管变量 <- 通道变量

例如: 从通道 ch 接管一个值,并且赋值给变量 x

x := <-ch

## 敞开详情见 [敞开通道](channel_close.md)。# 例子## 搭配 goroutine```gopackage mainfunc main() {    ch := make(chan string) // 没有设置通道的长度    go func() {        ch <- "hello world"    }()    msg := <-ch // 始终阻塞,直到接管到通道音讯    println(msg)}// $ go run main.go// 输入如下/**  hello world*/```## 死锁```gopackage mainfunc main() {    ch := make(chan string) // 没有设置通道的长度    ch <- "hello world" // 向通道发送数据,然而没有接收者    msg := <-ch // 代码执行不到这里, 因为下面阻塞发送数据时,就曾经死锁了    println(msg)}// $ go run main.go// 输入如下/**  fatal error: all goroutines are asleep - deadlock!  ...  ...  exit status 2*/```# 扩大浏览1. [死锁 - 维基百科](https://zh.wikipedia.org/wiki/%E6%AD%BB%E9%94%81)# 分割我![公众号](/img/bVc4MXa)