Skip to main content

time.NewTicker周期性定时器使用案例

Ticker是一个周期触发定时的计时器,它会按照一个时间间隔往channel发送系统当前时间,而channel的接收者可以以固定的时间间隔从channel中读取事件。

项目中试用的例子

package main

import (
"fmt"
"time"
)

func main() {

//创建一个周期性的定时器
ticker := time.NewTicker(3 * time.Second)

count := 1
//定义计数器
for {
select {
case t := <-ticker.C:
count++
fmt.Println("当前时间为:", t, "count = ", count)
}
case <-closeSig:
robots.CloseRobots()
logrus.Infof("ReqStat: %v", msgStat.DumpDefault(10))
fakeclient.PrintErrAckMap()
robot.DefaultCaseExeStat.String()
return nil
}
}
}

一.通过NewTicker函数定义定时器

package main

import (
"fmt"
"time"
)

func main() {

//创建一个周期性的定时器
ticker := time.NewTicker(3 * time.Second)
fmt.Println("当前时间为:", time.Now())

go func() {
for {

//从定时器中获取数据
t := <-ticker.C
fmt.Println("当前时间为:", t)

}
}()

for {
time.Sleep(time.Second * 1)
}
}

二.停止定时器

package main

import (
"fmt"
"runtime"
"time"
)

func main() {

//创建一个周期性的定时器
ticker := time.NewTicker(3 * time.Second)

//定义计数器
count := 1
fmt.Println("当前时间为:", time.Now(), "count = ", count)

go func() {
for {
//从定时器中获取数据
t := <-ticker.C
count++
fmt.Println("当前时间为:", t, "count = ", count)
if count == 10 {
/**
如果周期性定时被消费10次后就停止该定时器
*/
ticker.Stop()
runtime.Goexit()
}
}
}()

for {
time.Sleep(time.Second * 1)
}
}

img