mirror of
https://gitee.com/johng/gf.git
synced 2024-12-02 12:17:53 +08:00
69 lines
1.7 KiB
Go
69 lines
1.7 KiB
Go
|
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
||
|
//
|
||
|
// This Source Code Form is subject to the terms of the MIT License.
|
||
|
// If a copy of the MIT was not distributed with this file,
|
||
|
// You can obtain one at https://github.com/gogf/gf.
|
||
|
|
||
|
package gtimer
|
||
|
|
||
|
import "time"
|
||
|
|
||
|
// loop starts the ticker using a standalone goroutine.
|
||
|
func (t *Timer) loop() {
|
||
|
go func() {
|
||
|
var (
|
||
|
currentTimerTicks int64
|
||
|
timerIntervalTicker = time.NewTicker(t.options.Interval)
|
||
|
)
|
||
|
defer timerIntervalTicker.Stop()
|
||
|
for {
|
||
|
select {
|
||
|
case <-timerIntervalTicker.C:
|
||
|
// Check the timer status.
|
||
|
switch t.status.Val() {
|
||
|
case StatusRunning:
|
||
|
// Timer proceeding.
|
||
|
currentTimerTicks = t.ticks.Add(1)
|
||
|
if currentTimerTicks >= t.queue.LatestPriority() {
|
||
|
t.proceed(currentTimerTicks)
|
||
|
}
|
||
|
|
||
|
case StatusStopped:
|
||
|
// Do nothing.
|
||
|
|
||
|
case StatusClosed:
|
||
|
// Timer exits.
|
||
|
return
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}()
|
||
|
}
|
||
|
|
||
|
// proceed proceeds the timer job checking and running logic.
|
||
|
func (t *Timer) proceed(currentTimerTicks int64) {
|
||
|
var (
|
||
|
value interface{}
|
||
|
)
|
||
|
for {
|
||
|
value = t.queue.Pop()
|
||
|
if value == nil {
|
||
|
break
|
||
|
}
|
||
|
job := value.(*Job)
|
||
|
// It checks if it meets the ticks requirement.
|
||
|
if jobNextTicks := job.nextTicks.Val(); currentTimerTicks < jobNextTicks {
|
||
|
// It push the job back if current ticks does not meet its running ticks requirement.
|
||
|
t.queue.Push(job, job.nextTicks.Val())
|
||
|
break
|
||
|
}
|
||
|
// It checks the job running requirements and then does asynchronous running.
|
||
|
job.doCheckAndRunByTicks(currentTimerTicks)
|
||
|
// Status check: push back or ignore it.
|
||
|
if job.Status() != StatusClosed {
|
||
|
// It pushes the job back to queue for next running.
|
||
|
t.queue.Push(job, job.nextTicks.Val())
|
||
|
}
|
||
|
}
|
||
|
}
|