Golang

关注公众号 jb51net

关闭
首页 > 脚本专栏 > Golang > Golang结构体time.Ticker

详解Golang time包中的结构体time.Ticker

作者:路多辛

在日常开发过程中,会频繁遇到对时间进行操作的场景,使用 Golang 中的 time 包可以很方便地实现对时间的相关操作,接下来的几篇文章会详细讲解 time 包,本文讲解一下 time 包中的结构体 time.Ticker,需要的朋友可以参考下

time.Ticker

time.Ticker 会按照一个指定的时间间隔周期性地往一个 channel 中发送一个 time.Time 类型的数据,channel的 接收者可以以这个固定的时间间隔从 channel 中读取这个数据,常用于实现定时相关的功能。结构体定义和对应的方法如下:

type Ticker struct {
	C <-chan Time // The channel on which the ticks are delivered.
	r runtimeTimer
}

有两个方法:

使用示例

可以使用 time.NewTicker 函数创建一个 Ticker 实例,简单使用示例如下:

package main
import (
	"fmt"
	"time"
)
func main() {
	ticker := time.NewTicker(time.Second) // 每隔1s进行一次打印
	defer ticker.Stop()
	count := 0
	for {
		<-ticker.C
		fmt.Println("Tick")
		count++
		if count > 2 {
			ticker.Reset(2 * time.Second)
		}
		if count > 5 {
			break
		}
	}
}

首先创建了一个  time.Ticker 对象,时间间隔为1秒,第 3 次之后将时间间隔改为 2 秒,第 6 次后退出循环。

到此这篇关于详解Golang time包中的结构体time.Ticker的文章就介绍到这了,更多相关Golang结构体time.Ticker内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文