go的channel 默认的情况下,如果写入了数据没有被读取走,或者读取一个空的channel就会导致阻塞的情况
如果逻辑有问题,比如channel 一直没有写入数据,而有一段代码又在读取channel,则会触发deadlock
panic
我们可以使用 time模块的After 函数来实现,等待多少时间内,channel 没有数据,就超时,程序继续往下执行
使用time.After 实现channel 等待超时
这个demo 中我没有往channel中写任何数据,然后使用了select 去监控两个channel,正常情况下,这种情况会阻塞 导致 deadlock 因为channel中没有任何数据, select 那里又在读取数据阻塞, 但是使用了After 就可以指定只等待多长的时间
package main
import (
"fmt"
"time"
)
func ChannelTimeOut() {
ch1 := make(chan string, 10)
ch2 := make(chan string, 10)
fmt.Println("into ChannelTimeOut")
select {
case c1 := <-ch1:
fmt.Println("data from channel #1", c1)
case c2 := <-ch2:
fmt.Println("data from channel #2", c2)
// 如果把这个注释掉,则会阻塞 deadlock
case <-time.After(5 * time.Second):
fmt.Println("TimeOut")
}
fmt.Println("Outside select")
}
func main(){
ChannelTimeOut()
}