select中default的疑惑

netaxcess · 2019-09-25 13:00:34 · 1859 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2019-09-25 13:00:34 的主题,其中的信息可能已经有所发展或是发生改变。

1.png

这段代码一直打印deault,不会进入 case time := <-Delay.C:

2.png

把select中的default干掉,就会打印时间。 请问这个是啥原因啊?


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1859 次点击  
加入收藏 微博
10 回复  |  直到 2019-10-01 20:38:32
jan-bar
jan-bar · #1 · 5年之前

很正常啊。。default本来就是这样用的啊。。上面case没有匹配的立即执行default里面的啊。
这个一般用于那种不想阻塞等待chan的场景,及chan里面有就处理,没有就走default啊。

fenglangjuxu
fenglangjuxu · #2 · 5年之前

问题不在default这里 应该是你的 Delay.Reset(times) 搞的鬼 你把这个去掉试试 如果你想 实现一秒打印一次 那你应该用这个

time.NewTicker(times)
netaxcess
netaxcess · #3 · 5年之前
fenglangjuxufenglangjuxu #2 回复

问题不在default这里 应该是你的 Delay.Reset(times) 搞的鬼 你把这个去掉试试 如果你想 实现一秒打印一次 那你应该用这个 ``` time.NewTicker(times) ```

修改成了time.NewTicker(times),也去掉了Delay.Reset(times),依然只走fmt.Println("default"),还是不会走进fmt.Println(time)

fenglangjuxu
fenglangjuxu · #4 · 5年之前
package main

import (
    "fmt"
    "time"
)

func main() {
    times := 1 * time.Second
    dd := time.NewTicker(times)
    defer dd.Stop()
    for {
        //dd.Reset(times)
        select {
        case tt := <-dd.C:
            fmt.Println(tt)
        default:
            fmt.Println("default")
        }
    }
}
➜  [/code/go/src/tools] go run del.go|grep -v 'default'
2019-09-26 14:13:07.884333 +0800 CST m=+1.003279203
2019-09-26 14:13:08.883453 +0800 CST m=+2.002433911
2019-09-26 14:13:09.884568 +0800 CST m=+3.003584212
sdghchj
sdghchj · #5 · 5年之前

每次走default后你就重置了定时,当然不会执行定时任务。 要执行了定时任务后再重置定时时间。

sdghchj
sdghchj · #6 · 5年之前
package main

import (
    "fmt"
    "time"
)

func main() {
    times := 1 * time.Second
    dd := time.NewTicker(times)
    defer dd.Stop()
    for {
        select {
        case tt := <-dd.C:
            fmt.Println(tt)
            dd.Reset(times)
        default:
            fmt.Println("default")
        }
    }
}
netaxcess
netaxcess · #7 · 5年之前
sdghchjsdghchj #6 回复

``` package main import ( "fmt" "time" ) func main() { times := 1 * time.Second dd := time.NewTicker(times) defer dd.Stop() for { select { case tt := <-dd.C: fmt.Println(tt) dd.Reset(times) default: fmt.Println("default") } } } ```

谢谢。搞定。。

TryHenry
TryHenry · #8 · 5年之前

没看出楼主想要做什么,如果是测试的select的特性的话,可以参考下我补充的这段代码

for{
    select{
        case time := <-Delay.C:
            fmt.Println(time)
            Delay.Reset(times)
        default:
            fmt.Println("default")
            time.Sleep(time.Millisecond * 500)
    }
}
TryHenry
TryHenry · #9 · 5年之前
sdghchjsdghchj #6 回复

``` package main import ( "fmt" "time" ) func main() { times := 1 * time.Second dd := time.NewTicker(times) defer dd.Stop() for { select { case tt := <-dd.C: fmt.Println(tt) dd.Reset(times) default: fmt.Println("default") } } } ```

dd.Reset(times) 复制你代码的时候,这里的方法我提示用不了。 --go版本1.12

sdghchj
sdghchj · #10 · 5年之前
TryHenryTryHenry #9 回复

#6楼 @sdghchj dd.Reset(times) 复制你代码的时候,这里的方法我提示用不了。 --go版本1.12

我复制的楼上的,Reset应该是NewTimer的成员

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传