AddFunc中使用Prev的小坑
使用 cron 包的定时功能,可以实现不等时间的定时,但我这里就简单的每一分钟执行一次计划。
计划是统计 上次触发 到 现在 这个时间段之间的某些信息,我本以为使用cron的Prev就能很好的实现,但是测试时发现Prev的时间几乎就是本次执行的时间。
代码是这样的:
func main() {
cronSpec:= "0 */1 * * * ?"
timeLayout := "2006-01-02_15:04:05"
c := cron.New()
_ = c.AddFunc(cronSpec, func() {
fmt.Print("now: ", time.Now().Format(timeLayout))
fmt.Printf("\nc.Entries()[0].Prev:%s\nc.Entries()[0].Next:%s",
c.Entries()[0].Prev.Format(timeLayout), c.Entries()[0].Next.Format(timeLayout))
})
c.Start()
select {}
}
执行结果是这样的:
now: 2019-08-15_16:21:00
c.Entries()[0].Prev:2019-08-15_16:21:00
c.Entries()[0].Next:2019-08-15_16:22:00now: 2019-08-15_16:22:00
c.Entries()[0].Prev:2019-08-15_16:22:00
c.Entries()[0].Next:2019-08-15_16:23:00
明显不是我要的效果,难道是因为在func()内获取上次时间,所以触发的时候已经更新过了Prev和Next ?
但不管啥原因,问题是总要解决的。
我的解决办法是直接动手改掉cron包的内容(我也不知道这样是不是被允许的。。)
给它增加个上上次的时间字段,这样不就解决了吗~
找到cron.go文件,修改如下内容:
这样就简单粗暴的给它加了个上上次时间(Preprev),解决了我的问题,同时代码修改如下:
c := cron.New()
_ = c.AddFunc(cronSpec, func() {
fmt.Print("now: ", time.Now().Format(timeLayout))
if c.Entries()[0].Preprev.IsZero() {
fmt.Print(", and execute first time")
} else {
fmt.Printf("\nc.Entries()[0].Preprev:%s\nc.Entries()[0].Next:%s",
c.Entries()[0].Preprev.Format(timeLayout), c.Entries()[0].Next.Format(timeLayout))
}
})
c.Start()
现在执行效果如下:
now: 2019-08-15_16:56:00, and execute first time
now: 2019-08-15_16:57:00
c.Entries()[0].Preprev:2019-08-15_16:56:00
c.Entries()[0].Next:2019-08-15_16:58:00now: 2019-08-15_16:58:00
c.Entries()[0].Preprev:2019-08-15_16:57:00
c.Entries()[0].Next:2019-08-15_16:59:00
完毕!