• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Go语言如何并发超时处理详解

    实现原理:

    并发一个函数,等待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...")
     }
    }

    总结

    以上就是这篇文章的全部内容,希望对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。

    您可能感兴趣的文章:
    • 在Go中构建并发TCP服务器
    • Go 并发实现协程同步的多种解决方法
    • 详解Golang 中的并发限制与超时控制
    • 如何利用Golang写出高并发代码详解
    • go并发实现素数筛的代码
    上一篇:浅析Go语言中的Range关键字
    下一篇:利用Go语言实现简单Ping过程的方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Go语言如何并发超时处理详解 语言,如何,并发,超时,处理,