go语言从例子开始之Example27.超时处理
2019-10-28 15:21 _天枢 阅读(233) 评论(0) 编辑 收藏 举报超时 对于一个连接外部资源,或者其它一些需要花费执行时间的操作的程序而言是很重要的。得益于通道和 select
,在 Go中实现超时操作是简洁而优雅的。
Example:
package main import "fmt" import "time" func main(){ c1 := make(chan string) //在我们的例子中,假如我们执行一个外部调用,并在 2 秒后通过通道 c1 返回它的执行结果。 go func(){ time.Sleep(time.Second * 2) c1 <- "one" }() //这里是使用 select 实现一个超时操作。res := <- c1 等待结果,<-Time.After 等待超时时间 1 秒后发送的值。 //由于 select 默认处理第一个已准备好的接收操作,如果这个操作超过了允许的 1 秒的话,将会执行超时 case。 select{ case res:= <-c1: fmt.Println(res) case <- time.After(time.Second * 1): fmt.Println("timeout 1") } c2 := make(chan string) go func(){ time.Sleep(time.Second * 2) c2 <- "two" }() select{ case res := <-c2: fmt.Println(res) case <- time.After(time.Second * 3): fmt.Println("timeount 2") } }
Result:
$ go run example.go
timeout 1
two
运行这个程序,首先显示运行超时的操作,然后是成功接收的。
使用这个 select
超时方式,需要使用通道传递结果。这对于一般情况是个好的方式,因为其他重要的 Go 特性是基于通道和select
的。
作 者:
天枢
出 处:
http://www.cnblogs.com/yhleng/
关于作者:专注于软件自动化测试领域。如有问题或建议,请多多赐教!
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
特此声明:所有评论和私信都会在第一时间回复。也欢迎园子的大大们指正错误,共同进步。或者
直接私信我
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角
【
推荐】
一下。您的鼓励是作者坚持原创和持续写作的最大动力!