定时器与定时器通道(Tickers)

GolangGolangBeginner
立即练习

This tutorial is from open-source community. Access the source code

💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版

简介

本实验是关于在 Go 语言中使用定时器(tickers)。当你想要定期重复执行某些操作时,就会用到定时器。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL go(("`Golang`")) -.-> go/ConcurrencyGroup(["`Concurrency`"]) go/ConcurrencyGroup -.-> go/tickers("`Tickers`") subgraph Lab Skills go/tickers -.-> lab-15520{{"`定时器与定时器通道(Tickers)`"}} end

定时器与定时器通道(Tickers)

在本实验中,你需要创建一个每500毫秒触发一次的定时器通道(ticker),直到我们停止它。你将使用一个通道来等待值的到来。

  • 使用time包创建一个定时器通道(ticker)。
  • 使用一个通道来等待值的到来。
  • 使用select语句从通道接收值。
  • 在1600毫秒后停止定时器通道(ticker)。
## 当我们运行这个程序时,定时器通道(ticker)应该在我们停止它之前触发3次。
$ go run tickers.go
Tick at 2012-09-23 11:29:56.487625 -0700 PDT
Tick at 2012-09-23 11:29:56.988063 -0700 PDT
Tick at 2012-09-23 11:29:57.488076 -0700 PDT
Ticker stopped

以下是完整代码:

// [定时器](timers) 用于在未来某个时间点执行一次操作,而 _定时器通道(tickers)_ 用于定期重复执行操作。这是一个定时器通道(ticker)的示例,它会定期触发,直到我们停止它。

package main

import (
	"fmt"
	"time"
)

func main() {

	// 定时器通道(Tickers)使用与定时器类似的机制:一个会发送值的通道。在这里,我们将使用通道上的 `select` 内置函数来等待每500毫秒到达的值。
	ticker := time.NewTicker(500 * time.Millisecond)
	done := make(chan bool)

	go func() {
		for {
			select {
			case <-done:
				return
			case t := <-ticker.C:
				fmt.Println("Tick at", t)
			}
		}
	}()

	// 定时器通道(Tickers)可以像定时器一样停止。一旦定时器通道(ticker)停止,它将不会再从其通道接收任何值。我们将在1600毫秒后停止我们的定时器通道(ticker)。
	time.Sleep(1600 * time.Millisecond)
	ticker.Stop()
	done <- true
	fmt.Println("Ticker stopped")
}

总结

在本实验中,你学习了如何在Go语言中使用定时器通道(tickers)。你创建了一个每500毫秒触发一次的定时器通道(ticker),直到我们停止它,使用一个通道来等待值的到来,并在1600毫秒后停止了定时器通道(ticker)。

您可能感兴趣的其他 Golang 教程