详解Golang 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 次后退出循环。
到此这篇关于详解Golang time包中的结构体time.Ticker的文章就介绍到这了,更多相关Golang结构体time.Ticker内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
go defer return panic 执行顺序示例详解
这篇文章主要介绍了go defer return panic 执行顺序,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-01-01
基于golang channel实现的轻量级异步任务分发器示例代码
这篇文章主要给大家介绍了关于基于golang channel实现的轻量级异步任务分发器的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2018-07-07


最新评论