定时器结构修改

This commit is contained in:
kercylan98 2023-04-20 16:38:59 +08:00
parent 5a3f4ec0a1
commit ba0b9f7508
4 changed files with 34 additions and 30 deletions

View File

@ -2,7 +2,12 @@ package timer
import "time" import "time"
var ( const (
// 时间轮一刻度长度 timingWheelTick = time.Millisecond * 10 // 时间轮一刻度长度
timingWheelTick = time.Millisecond * 10 )
const (
Forever = -1 // 无限循环
Once = 1 // 一次
Instantly = 0 // 立刻
) )

View File

@ -23,7 +23,7 @@ type Scheduler struct {
timer *timingwheel.Timer timer *timingwheel.Timer
manager *Manager ticker *Ticker
lock sync.RWMutex lock sync.RWMutex
} }
@ -65,7 +65,7 @@ func (slf *Scheduler) Caller() {
slf.trigger++ slf.trigger++
if slf.total > 0 && slf.trigger >= slf.total { if slf.total > 0 && slf.trigger >= slf.total {
slf.lock.Unlock() slf.lock.Unlock()
slf.manager.StopTimer(slf.name) slf.ticker.StopTimer(slf.name)
} else { } else {
slf.lock.Unlock() slf.lock.Unlock()
} }

View File

@ -8,8 +8,8 @@ import (
"github.com/RussellLuo/timingwheel" "github.com/RussellLuo/timingwheel"
) )
// Manager 管理器 // Ticker 管理器
type Manager struct { type Ticker struct {
timer *Timer timer *Timer
wheel *timingwheel.TimingWheel wheel *timingwheel.TimingWheel
timers map[string]*Scheduler timers map[string]*Scheduler
@ -17,7 +17,7 @@ type Manager struct {
} }
// Release 释放管理器,并将管理器重新放回 Timer 池中 // Release 释放管理器,并将管理器重新放回 Timer 池中
func (slf *Manager) Release() { func (slf *Ticker) Release() {
slf.timer.lock.Lock() slf.timer.lock.Lock()
defer slf.timer.lock.Unlock() defer slf.timer.lock.Unlock()
@ -30,11 +30,11 @@ func (slf *Manager) Release() {
slf.lock.Unlock() slf.lock.Unlock()
slf.timer.Managers = append(slf.timer.Managers, slf) slf.timer.tickers = append(slf.timer.tickers, slf)
} }
// StopTimer 停止特定名称的调度器 // StopTimer 停止特定名称的调度器
func (slf *Manager) StopTimer(name string) { func (slf *Ticker) StopTimer(name string) {
slf.lock.Lock() slf.lock.Lock()
defer slf.lock.Unlock() defer slf.lock.Unlock()
@ -45,7 +45,7 @@ func (slf *Manager) StopTimer(name string) {
} }
// IsStopped 特定名称的调度器是否已停止 // IsStopped 特定名称的调度器是否已停止
func (slf *Manager) IsStopped(name string) bool { func (slf *Ticker) IsStopped(name string) bool {
slf.lock.RLock() slf.lock.RLock()
defer slf.lock.RUnlock() defer slf.lock.RUnlock()
if s, ok := slf.timers[name]; ok { if s, ok := slf.timers[name]; ok {
@ -55,7 +55,7 @@ func (slf *Manager) IsStopped(name string) bool {
} }
// GetSchedulers 获取所有调度器名称 // GetSchedulers 获取所有调度器名称
func (slf *Manager) GetSchedulers() []string { func (slf *Ticker) GetSchedulers() []string {
slf.lock.RLock() slf.lock.RLock()
defer slf.lock.RUnlock() defer slf.lock.RUnlock()
names := make([]string, 0, len(slf.timers)) names := make([]string, 0, len(slf.timers))
@ -66,12 +66,12 @@ func (slf *Manager) GetSchedulers() []string {
} }
// After 设置一个在特定时间后运行一次的调度器 // After 设置一个在特定时间后运行一次的调度器
func (slf *Manager) After(name string, after time.Duration, handleFunc interface{}, args ...interface{}) { func (slf *Ticker) After(name string, after time.Duration, handleFunc interface{}, args ...interface{}) {
slf.Loop(name, after, timingWheelTick, 1, handleFunc, args...) slf.Loop(name, after, timingWheelTick, 1, handleFunc, args...)
} }
// Loop 设置一个在特定时间后仿佛运行的调度器 // Loop 设置一个在特定时间后反复运行的调度器
func (slf *Manager) Loop(name string, after, interval time.Duration, times int, handleFunc interface{}, args ...interface{}) { func (slf *Ticker) Loop(name string, after, interval time.Duration, times int, handleFunc interface{}, args ...interface{}) {
slf.StopTimer(name) slf.StopTimer(name)
if after < timingWheelTick { if after < timingWheelTick {
@ -93,7 +93,7 @@ func (slf *Manager) Loop(name string, after, interval time.Duration, times int,
total: times, total: times,
cbFunc: reflect.ValueOf(handleFunc), cbFunc: reflect.ValueOf(handleFunc),
cbArgs: values, cbArgs: values,
manager: slf, ticker: slf,
} }
slf.lock.Lock() slf.lock.Lock()
@ -101,4 +101,3 @@ func (slf *Manager) Loop(name string, after, interval time.Duration, times int,
scheduler.timer = slf.wheel.ScheduleFunc(scheduler, scheduler.caller) scheduler.timer = slf.wheel.ScheduleFunc(scheduler, scheduler.caller)
slf.lock.Unlock() slf.lock.Unlock()
} }

View File

@ -8,31 +8,31 @@ import (
var timer = new(Timer) var timer = new(Timer)
func GetManager(size int) *Manager { func GetTicker(size int) *Ticker {
return timer.NewManager(size) return timer.NewTicker(size)
} }
type Timer struct { type Timer struct {
Managers []*Manager tickers []*Ticker
lock sync.Mutex lock sync.Mutex
} }
func (slf *Timer) NewManager(size int) *Manager { func (slf *Timer) NewTicker(size int) *Ticker {
slf.lock.Lock() slf.lock.Lock()
defer slf.lock.Unlock() defer slf.lock.Unlock()
var manager *Manager var ticker *Ticker
if len(slf.Managers) > 0 { if len(slf.tickers) > 0 {
manager = slf.Managers[0] ticker = slf.tickers[0]
slf.Managers = slf.Managers[1:] slf.tickers = slf.tickers[1:]
return manager return ticker
} }
manager = &Manager{ ticker = &Ticker{
timer: slf, timer: slf,
wheel: timingwheel.NewTimingWheel(timingWheelTick, int64(size)), wheel: timingwheel.NewTimingWheel(timingWheelTick, int64(size)),
timers: make(map[string]*Scheduler), timers: make(map[string]*Scheduler),
} }
manager.wheel.Start() ticker.wheel.Start()
return manager return ticker
} }