NewTimer与 NewTicker的示例

让后台goroutine完成之前main函数不能退出,通常我们会采取下面几种手段来做控制:
– time.Sleep
– time.NewTimer
– time.NewTicker
– sync.WaitGroup

下面的代码对NewTimer与NewTicker做一个演示。

/**
*ticker只要定义完成,从此刻开始计时,不需要任何其他的操作,每隔固定时间都会触发。
*timer定时器,是到固定时间后会执行一次
*如果timer定时器要每隔间隔的时间执行,实现ticker的效果,使用 func (t *Timer) Reset(d Duration) bool
 */
func TestTTWithGoroutine(t *testing.T) {
    var wg sync.WaitGroup
    wg.Add(2)
    //NewTimer 创建一个 Timer,他会在最少过去时间段 d 后到期,向其自身的 C 字段发送当时的时间
    timer1 := time.NewTimer(2 * time.Second)

    //NewTicker 返回一个新的 Ticker,该 Ticker 包含一个通道字段,并会每隔时间段 d 就向该通道发送当时的时间。他会调
    //整时间间隔或者丢弃 tick 信息以适应反应慢的接收者。如果d <= 0会触发panic。关闭该 Ticker 可
    //以释放相关资源。
    ticker1 := time.NewTicker(2 * time.Second)

    go func(t *time.Ticker) {
        defer wg.Done()
        for {
            <-t.C
            fmt.Println("get ticker1", time.Now().Format("2006-01-02 15:04:05"))
        }
    }(ticker1)

    go func(t *time.Timer) {
        defer wg.Done()
        for {
            <-t.C
            fmt.Println("get timer", time.Now().Format("2006-01-02 15:04:05"))
            //Reset 使 t 重新开始计时,(本方法返回后再)等待时间段 d 过去后到期。如果调用时t
            //还在等待中会返回真;如果 t已经到期或者被停止了会返回假。
            t.Reset(2 * time.Second)
        }
    }(timer1)

    wg.Wait()
}

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注