为什么我的自定义“超时等待频道”不起作用以及如何使其起作用?
php小编小新在使用自定义“超时等待频道”时,可能会遇到它不起作用的情况。这可能是由于一些常见的问题导致的,例如错误的配置或代码问题。为了使自定义“超时等待频道”起作用,我们可以采取一些解决方法。首先,我们需要确保正确地配置了频道和超时时间。其次,我们可以检查代码中是否存在任何错误或逻辑问题,可能导致超时等待频道不起作用。最后,我们还可以考虑使用其他相关的技术或工具来处理超时等待问题,例如使用封装库或使用定时器来监控和处理超时情况。通过这些方法,我们可以使自定义“超时等待频道”正常工作,提高我们的应用程序的性能和稳定性。
问题内容
我正在尝试制作自己的自定义“频道超时”。更准确地说,是其中的 time.after
函数。换句话说,我正在尝试实现这个:
select {
case v := <-c:
fmt.println("value v: ", v)
case <-time.after(1 * time.second):
fmt.println("timeout")
}
但不幸的是我遇到了问题。
我的实现是:
func waitFun(wait int) chan int {
time.Sleep(time.Duration(wait) * time.Second)
c := make(chan int)
c <- wait
return c
}
func main() {
c := make(chan int)
go func() {
time.Sleep(3 * time.Second)
c <- 10
}()
select {
case v := <-c:
fmt.Println("Value v: ", v)
case <-waitFun(1):
fmt.Println("Timeout")
}
time.Sleep(4 * time.Second)
}
由于某种原因,这不起作用。错误是:all goroutine 正在休眠 - 死锁!
。我知道在某个时刻,所有 goroutine(main 和用匿名函数引入的 goroutine)都会进入睡眠状态,但这是错误的原因还是其他原因?我的意思是,这不是“无限睡眠”或“无限等待某事”,所以这不是死锁,对吧?另外,使用 time.after
也会让 goroutine 休眠,对吗?我需要更改什么才能使我的程序正常工作?
解决方法
select
语句将在运行时评估所有情况,因此此代码实际上会等待 waitfun
返回,然后才开始侦听任何通道。您必须更改 waitfun
以立即返回通道:
func waitFun(wait int) chan int {
c := make(chan int)
go func() {
time.Sleep(time.Duration(wait) * time.Second)
c <- wait
}()
return c
}
以上就是为什么我的自定义“超时等待频道”不起作用以及如何使其起作用?的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341