golang中channel的超时处理

并发中超时处理是必不可少的,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中读取到数据
	}
}
原文地址:https://www.cnblogs.com/xjshi/p/5371316.html