首页 > 后端开发 > Golang > 为什么我的自定义'超时等待频道”不起作用以及如何使其起作用?

为什么我的自定义'超时等待频道”不起作用以及如何使其起作用?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2024-02-12 23:06:09
转载
1111 人浏览过

为什么我的自定义超时等待频道”不起作用以及如何使其起作用?

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)都会进入睡眠状态,但这是错误的原因还是其他原因?我的意思是,这不是“无限睡眠”或“无限等待某事”,所以这不是死锁,对吧?另外,使用 all goroutine 正在休眠 - 死锁!。我知道在某个时刻,所有 goroutine(main 和用匿名函数引入的 goroutine)都会进入睡眠状态,但这是错误的原因还是其他原因?我的意思是,这不是“无限睡眠”或“无限等待某事”,所以这不是死锁,对吧?另外,使用 time.after 也会让 goroutine 休眠,对吗?我需要更改什么才能使我的程序正常工作?

解决方法

select 语句将在运行时评估所有情况,因此此代码实际上会等待 waitfun 返回,然后才开始侦听任何通道。您必须更改 waitfun 也会让 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
}
登录后复制

以上是为什么我的自定义'超时等待频道”不起作用以及如何使其起作用?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:stackoverflow.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板