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)
}
}