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 比较的例子。...

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

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