Go语言如何并发超时处理详解
更新时间:2016年09月13日 14:27:38 投稿:daisy
大家都知道golang并没有在语言层次上提供超时操作,但可以通过一些小技巧实现超时。下面来一起看看吧,有需要的朋友们可以参考借鉴。
实现原理:
并发一个函数,等待1s后向timeout写入数据,在select中如果1s之内有数据向其他channel写入则会顺利执行,如果没有,这是timeout写入了数据,则我们知道超时了。
实现代码:
package main
import "fmt"
import "time"
func main() {
ch := make(chan int, 1)
timeout := make(chan bool, 1)
// 并发执行一个函数,等待1s后向timeout写入true
go func() {
time.Sleep(1000)
timeout <- true
}()
// 这里会等待ch或timeout读出数据
// 因为一直没有向ch写入数据
// 在1s后向timeout写入了数据
// 所以执行了timeout的case
// 利用这个技巧可以实现超时操作
select {
case <- ch :
fmt.Println("read from ch")
case <- timeout :
fmt.Println("time out...")
}
}
总结
以上就是这篇文章的全部内容,希望对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。
相关文章
Kubernetes上使用Jaeger分布式追踪基础设施详解
这篇文章主要为大家介绍了Kubernetes上使用Jaeger分布式追踪基础设施详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-03-03
Go语言Web编程实现Get和Post请求发送与解析的方法详解
这篇文章主要介绍了Go语言Web编程实现Get和Post请求发送与解析的方法,结合实例形式分析了Go语言客户端、服务器端结合实现web数据get、post发送与接收数据的相关操作技巧,需要的朋友可以参考下2017-06-06


最新评论