Go Wiki:超时和截止时间

要放弃运行时间过长的同步调用,请使用带 time.After 的 select 语句

import "time"

c := make(chan error, 1)
go func() { c <- client.Call("Service.Method", args, &reply) } ()
select {
  case err := <-c:
    // use err and reply
  case <-time.After(timeoutNanoseconds):
    // call timed out
}

请注意,通道 c 的缓冲区大小为 1。如果它是一个无缓冲通道,并且 client.Call 方法花费的时间超过 timeoutNanoseconds,则通道发送将永远阻塞,并且 goroutine 永远不会被销毁。

参考

time.After:https://pkg.go.dev/time/#After

select:https://go-lang.org.cn/ref/spec#Select_statements

博客文章:https://go-lang.org.cn/blog/2010/09/go-concurrency-patterns-timing-out-and.html


此内容是 Go Wiki 的一部分。