- 如果没有缓冲区,单纯的往其中放入元素立马就会进入阻塞状态,必须有其他的线程从其中取走元素。通俗的讲要有一个线程不断的取这个管道的元素,才能往其中放入元素。它就像一个窄窄的门框,进去就得出来。
- 而有一个缓冲区的管道想一段地道,放入的元素不会马上进入阻塞状态,只有第二个准备进入而第一个还没有进入的情况下才会阻塞。
func main() { intChan := make(chan int)
intChan <- 1
close(intChan)
}运行结果:
fatal error: all goroutines are asleep - deadlock!goroutine 1 [chan send]:
main.main()
C:/Users/86155/go/src/groutinueTest/mianshi.go:19 +0x5c
exit status 2
【管道channel 有无缓冲区的区别】没有线程往管道里面取东西,往里面放东西就会立马进入死锁,因为没有线程从里面拿走。
加入一个不断从管道取走元素的线程,程序正常不会进入死锁。
func main() { intChan := make(chan int, 1)
go func() {
for {
v, ok := <-intChan
if !ok {
break
}else{
fmt.Println(v)
}
}
}()
intChan <- 1
close(intChan)
time.Sleep(time.Second * 3)
}运行结果:
1
有一个缓冲区的管道示例:
func main() { intChan := make(chan int, 1)
intChan <- 1
close(intChan)
}运行结果:
正常
推荐阅读
- Go|Docker后端部署详解(Go+Nginx)
- GO|GO,GO,GO!
- Go成长之路|go中判断空字符串、nil和len(t)的用法
- go编译tools
- go grpc安装与使用
- goroutine 调度原理
- Go|Go进阶之路——复杂类型
- Go进阶之路——变量
- Go进阶之路——流程控制语句