golang中channel的超时处理

时间:2022-11-22 08:26:31

并发中超时处理是必不可少的,golang没有提供直接的超时处理机制,但可以利用select机制来解决超时问题。

func timeoutFunc() {
//首先,实现并执行一个匿名的超时等待函数
timeout := make(chan bool, 1)
go func() {
time.Sleep(1e9)//等待1秒钟
timeout <- true
}()

//然后,我们把timeout这个channel利用起来
select {
case <- ch:
//从ch中读到数据
case <- timeout:
//一直没有从ch中读取到数据,但从timeout中读取到数据
}
}