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 GD32 SPI通信时我从机原样返回收到的数据怎么弄?
  • ¥15 phython读取excel表格报错 ^7个 SyntaxError: invalid syntax 语句报错
  • ¥20 @microsoft/fetch-event-source 流式响应问题
  • ¥15 ogg dd trandata 报错
  • ¥15 高缺失率数据如何选择填充方式
  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?