当前位置: 首页>>编程语言>>正文


Go语言教程:超时处理

返回Go语言教程首页

概念简介

超时对于一个连接外部资源,或者其它一些需要花费执行时间
的操作的程序而言是很重要的。得益于通道和 `select`,在 Go
中实现超时操作是简洁而优雅的。

例程代码


package main

import "time"
import "fmt"

func main() {

    // 在我们的例子中,假如我们执行一个外部调用,并在 2 秒后
    // 通过通道 `c1` 返回它的执行结果。
    c1 := make(chan string, 1)
    go func() {
        time.Sleep(time.Second * 2)
        c1 <- "result 1"
    }()

    // 这里是使用 `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")
    }

    // 如果我允许一个长一点的超时时间 3 秒,将会成功的从 `c2`
    // 接收到值,并且打印出结果。
    c2 := make(chan string, 1)
    go func() {
        time.Sleep(time.Second * 2)
        c2 <- "result 2"
    }()
    select {
    case res := <-c2:
        fmt.Println(res)
    case <-time.After(time.Second * 3):
        fmt.Println("timeout 2")
    }
}

执行&输出


# 运行这个程序,首先显示运行超时的操作,然后是成功接收的。
$ go run timeouts.go 
timeout 1
result 2

# 使用这个 `select` 超时方式,需要使用通道传递结果。这对于
# 一般情况是个好的方式,因为其他重要的 Go 特性是基于通道和
# `select` 的。接下来我们就要看到两个例子:timer 和 ticker。

课程导航

学习上一篇:Go语言教程:通道选择器    学习下一篇:Go语言教程:非阻塞通道操作

相关资料

本例程github源代码:https://github.com/xg-wang/gobyexample/tree/master/examples/timeouts

Go语言超时处理

本文由《纯净天空》出品。文章地址: https://vimsky.com/article/4050.html,未经允许,请勿转载。