首页 > 其他 > 详细

Go 采用 time.After 实现超时控制

时间:2019-08-05 14:44:04      阅读:86      评论:0      收藏:0      [点我收藏+]
场景:
假设业务中需调用服务接口A,要求超时时间为5秒,那么如何优雅、简洁的实现呢?

我们可以采用select+time.After的方式,十分简单适用的实现。

time.After()表示time.Duration长的时候后返回一条time.Time类型的通道消息。那么,基于这个函数,就相当于实现了定时器,且是无阻塞的。

超时控制的代码实现:
package main

import (
    "fmt"
    "time"
)

func main() {
    ch := make(chan string)

    go func() {
        fmt.Println("go func start....")
        time.Sleep(time.Second * 2)

        ch <- "result"
    }()

    select {
    //第一个case里阻塞的时间只有比第二个case阻塞的时间长的时候, 才能执行第二个case
    case res := <-ch:
        fmt.Println(res)
    case <-time.After(time.Second * 1):
        fmt.Println("timeout")
    }
}


我们使用channel来接收协程里的业务返回值。
select语句阻塞等待最先返回数据的channel,当先接收到time.After的通道数据时,select则会停止阻塞并执行该case的代码。此时就已经实现了对业务代码的超时处理。

Go 采用 time.After 实现超时控制

原文:https://www.cnblogs.com/nyist-xsk/p/11302743.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!