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
}

有两个方法:

  • func (t *Ticker) Reset(d Duration),停止计时器并将其周期重置为指定的时间间隔。
  • func (t *Ticker) Stop(),关闭计时器,调用此方法之后,将不再发送 tick。

使用示例

可以使用 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 次后退出循环。

相关推荐
_OP_CHEN1 小时前
C++基础:(十二)list类的基础使用
开发语言·数据结构·c++·stl·list类·list核心接口·list底层原理
uzong2 小时前
一次慢接口背后,竟藏着40+种可能!你中过几个
后端·面试·程序员
G探险者3 小时前
滴滴P0级故障背后:互联网公司是如何分级处理线上事故的?
后端
G探险者3 小时前
从 Tomcat 与 Jetty 的对比,聊聊影响一个服务并发能力的关键因素
后端
你的人类朋友4 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
ONE_PUNCH_Ge4 小时前
Go 语言变量
开发语言
幼稚园的山代王4 小时前
go语言了解
开发语言·后端·golang
kkjt01304 小时前
{MySQL查询性能优化索引失效的八大场景与深度解决方案}
后端
zhuyasen4 小时前
踩坑实录:Go 1.25.x 编译的 exe 在 Windows 提示“此应用无法运行”
windows·golang
晚风残4 小时前
【C++ Primer】第六章:函数
开发语言·c++·算法·c++ primer