## 为什么在 for select 循环中使用 return 会导致阻塞?

## 为什么在 for select 循环中使用 return 会导致阻塞?

for select 中使用 return 导致的阻塞问题

for select 循环中使用 return 会导致整个函数返回,而不是只退出当前 case 分支。这可能会导致阻塞,特别是在 goroutine 中使用 for select 时。

在给定的代码中,monitor() 函数中使用了 return 语句。当 N() 返回 1 时,return 语句会让整个函数返回,而不是只退出 if n == 1 分支。

那么,为什么这会导致阻塞呢?

在主 goroutine 中,使用 NewCache() 调用多次创建了一个单例缓存实例,因此 _cache 始终指向同一个 Cache 实例。当我们从浏览器向 http://localhost:8080/add 发送请求时,这些请求会通过 Gin 路由器进入 GET /add 处理程序。

在处理程序中,我们使用 NewCache() 创建新缓存实例,并向其通道 ch 推送四个随机整数。但是,由于缓存实例实际上是同一个实例,这些消息实际上并没有被接收和处理。

同时,我们还启动了 monitor() goroutine 来监视 ch 通道。当通道中没有消息时,for select 会进入 default 分支,打印 "aaa"。但是,由于 return 语句,当 N() 返回 1 时,monitor() 函数会完全退出。

为什么 break continue 不行?

如果我们使用 break continue 而不是 return,那么 goroutine 不会退出,而是会继续执行 for select 循环。当有消息到达 ch 通道时,它将被接收并处理,请求将完成。

以上就是## 为什么在 for select 循环中使用 return 会导致阻塞?的详细内容,更多请关注www.sxiaw.com其它相关文章!