- 如果没有缓冲区,单纯的往其中放入元素立马就会进入阻塞状态,必须有其他的线程从其中取走元素。通俗的讲要有一个线程不断的取这个管道的元素,才能往其中放入元素。它就像一个窄窄的门框,进去就得出来。
- 而有一个缓冲区的管道想一段地道,放入的元素不会马上进入阻塞状态,只有第二个准备进入而第一个还没有进入的情况下才会阻塞。
没有缓冲区的管道示例:
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
没有线程往管道里面取东西,往里面放东西就会立马进入死锁,因为没有线程从里面拿走。
加入一个不断从管道取走元素的线程,程序正常不会进入死锁。
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)
}
运行结果:
正常