dongzhenyin2001 2016-06-08 01:26
浏览 52
已采纳

为什么在选择块中将其与股票代码配对后,时间永远不会触发?

I have a select block that is listening on 2 channels, a ticker and a timer:

package main

import (
    "fmt"
    "time"
)

func main() {

    ticker := time.NewTicker(5 * time.Second)
    for {
        select {
        case z := <-ticker.C:
            fmt.Printf("tick %d
", z)

        case <-time.After(12 * time.Second):
            fmt.Println("12 seconds elapsed!")
        }
    }
}

If I run the code, the time.After case never runs, but the ticker works correctly.

If I remove the ticker, time.After fires correctly:

package main

import (
    "fmt"
    "time"
)

func main() {

    for {
        select {
        case <-time.After(12 * time.Second):
            fmt.Println("12 seconds elapsed!")
        }
    }
}

It works correctly if I used a timer rather than time.After:

package main

import (
    "fmt"
    "time"
)

func main() {

    ticker := time.NewTicker(5 * time.Second)
    timer := time.NewTimer(12 * time.Second)
    for {
        select {
        case z := <-ticker.C:
            fmt.Printf("tick %d
", z)

        case <-timer.C:
            fmt.Println("12 seconds elapsed!")
        }
    }
}

Why does this happen?

  • 写回答

1条回答 默认 最新

  • dongzongzi0379 2016-06-08 02:38
    关注

    A select blocks until one of its cases is ready, then it executes that case. In your example time.After() never gets called.

    func main() {
    
        ticker := time.NewTicker(5 * time.Second)
        for {
            select {
            case z := <-ticker.C:
                fmt.Printf("tick %d
    ", z)
    
            //This never gets chance to be ready. It'll work if you make it less than 5 seconds.
            case <-time.After(12 * time.Second): 
                fmt.Println("12 seconds elapsed!")
            }
        }
    }
    

    You can get it working by having timer declared before for loop.

    func main() {
    
            ticker := time.NewTicker(5 * time.Second)
            timer := time.After(12 * time.Second)
            for {
                    select {
                    case z := <-ticker.C:
                            fmt.Printf("tick %d
    ", z)
    
                    case <-timer:
                            fmt.Println("12 seconds elapsed!")
                    }   
            }   
    }   
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?