怎么实现真正的goroutine超时?

lipengfeihb · · 1409 次点击
`都是串行的处理逻辑,没有合适的位置来监听ctx.Done()。` 具体场景具体对待。难道你想有一个通用的方法,在不知道某个goroutine运行情况时让runtime把这个goroutine强制结束掉?这样恐怕你的程序就变成不可控的了,充满不确定。搬砖还是要一块块的搬
#6
更多评论
第一点 我感觉你超时的用法有点错误了。 cancleFun()这个函数在你的代码中是无效的。这个函数的作用只有通知ctx.Done。而你使用WithTimeout倒计时结束后也会通知ctx.Done(). 第二点 超时结束不是程序就马上结束。你需要在代码层面进行处理才能结束,实际上他只有一个通知ctx.Done一个功能。 如果你想让你的goroutine在超时的时候结束,也很简单,主函数中相似的逻辑 实现在 goroutine中就可以了。 ``` //处理任务 func handleTask(ctx context.Context, ch chan bool, taskId int) { for i := 0; i < 5; i++ { select { case <-ctx.Done(): return default: time.Sleep(time.Second) fmt.Println(fmt.Sprintf("处理任务 %d:%d, %v", taskId, i, time.Now())) } } ch <- true } ```
#1
第一点认同。 第二点 感觉不太好实现,生产环境下handleTask()是没有for 的,都是串行的处理逻辑,没有合适的位置来监听ctx.Done()。
#2