zoukankan      html  css  js  c++  java
  • go语言从例子开始之Example27.超时处理

    超时 对于一个连接外部资源,或者其它一些需要花费执行时间的操作的程序而言是很重要的。得益于通道和 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 的。

    坐标: 上一个例子    下一个例子

  • 相关阅读:
    Keep at Most 100 Characters
    Larry and Inversions
    计算指数
    简单题
    重要的话说三遍
    I Love GPLT
    猜数字
    打印沙漏
    多态性(polymorphism),封装性(encapsulation),内聚(cohesion)以及耦合(coupling)的基本概念
    Hibernate面试题
  • 原文地址:https://www.cnblogs.com/yhleng/p/11752528.html
Copyright © 2011-2022 走看看