golang的通道(channel)可分为不带缓存的通道和带缓存的通道。用make函数创建通道的时候,如果不指定缓存大小,创建的就是不带缓存的通道。
向通道中放入数据的一端可以称为生产者,从通道获取数据的一端可以称为消费者。不带缓存的通道,在通道任意一端没有准备就绪之前,另一端就会产生阻塞。
生产者往channel写数据,但是channel满了,导致生产者阻塞。
Channel是Golang中非常重要的数据结构, golang的channel读或写是会造成阻塞的,但是可以用select的多路复用解决这个问题
package main
import "fmt"
func main() {
messages := make(chan string)
signals := make(chan bool)
select {
case msg := <-messages:
fmt.Println("received message", msg)
default:
fmt.Println("no message received")
}
msg := "hi"
select {
case messages <- msg:
fmt.Println("sent message", msg)
default:
fmt.Println("no message sent")
}
select {
case msg := <-messages:
fmt.Println("received message", msg)
case sig := <-signals:
fmt.Println("received signal", sig)
default:
fmt.Println("no activity")
}
}
select的多路复用(不阻塞读channel、非阻塞写入channel),可以用于检测某个通道是否满了,是否是空的
golang select default : select存在default的话,在case不命中的情况下,会直接进入default分支,协程一样会结束,不会阻塞住。