GolangNote

Golang笔记

golang channel 读写超时处理

Permalink

Go 语言的 channel 本身是不支持 timeout 的,所以一般实现 channel 的读写超时都采用 select

golang channel

如下:

Go: select channel
1
2
3
4
select {
case <-c:
case <-time.After(time.Second):
}

golang select机制

检查每个case语句

  • 如果有任意一个chan是send or recv read,那么就执行该block
  • 如果多个case是ready的,那么随机找1个并执行该block
  • 如果都没有ready,那么就block and wait
  • 如果有default block,而且其他的case都没有ready,就执行该default bloc

正确的 channel timeout 也许应该这么做 :

Go: channel timeout
1
2
3
4
5
6
7
8
to := time.NewTimer(time.Second)
for {
    to.Reset(time.Second)
    select {
    case <-c:
    case <-to.C:
    }
}

本文网址: https://golangnote.com/topic/8.html 转摘请注明来源

Related articles

Golang sync.WaitGroup 的 Wait 超时处理

sync.WaitGroup 使用 `Add(1)`、`Done()`、`Wait()`组合来实现多协程等待,如果某一协程未能合理处理错误,导致无法退出,此时需要引入超时机制。下面是一种超时处理方法。...

golang共享数据用Mutex 或 Channel

在go 里,多线程对共享数据的操作一般要使用Mutex 或 Channel 来加锁或隔离通信。下面是一个使用Mutex 和 Channel 比较的例子。...

Golang 单实例实现网站多域名请求

有时候写网站,为了统一的后端,把不同业务都集中到一个后端,这时就需要处理多域名的请求,在 Go http server 里实现很简单,只需把不同域名映射到不同的 `http.Handler`。...

谷歌翻译的 golang 库推荐

Google 的翻译越来越好了,官方的Golang SDK 已经很完美,这里介绍的是几个非官方发布的有特色的库。...

Write a Comment to "golang channel 读写超时处理"

Submit Comment Login
Based on Golang + fastHTTP + sdb | go1.22.3 Processed in 0ms