ztimer

package
v1.3.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 8, 2022 License: MIT Imports: 7 Imported by: 0

Documentation

Index

Constants

View Source
const (
	HOUR_NAME     = "HOUR"
	HOUR_INTERVAL = 60 * 60 * 1e3 // ms为精度
	HOUR_SCALES   = 12

	MINUTE_NAME     = "MINUTE"
	MINUTE_INTERVAL = 60 * 1e3
	MINUTE_SCALES   = 60

	SECOND_NAME     = "SECOND"
	SECOND_INTERVAL = 1e3
	SECOND_SCALES   = 60

	TIMERS_MAX_CAP = 2048 // 每个时间轮刻度挂载定时器的最大个数
)
View Source
const (
	// 默认缓冲触发函数队列大小
	MAX_CHAN_BUFF = 2048
	// 默认最大误差时间
	MAX_TIME_DELAY = 100
)

Variables

This section is empty.

Functions

func UnixMilli

func UnixMilli() int64

UnixMilli 返回1970-1-1至今经历的毫秒数

Types

type DelayFunc

type DelayFunc struct {
	// contains filtered or unexported fields
}

DelayFunc 定义一个延迟调用函数

延迟调用函数就是 时间定时器超时的时候,触发的事先注册好的回调函数

func NewDelayFunc

func NewDelayFunc(f func(v ...interface{}), args []interface{}) *DelayFunc

NewDelayFunc 创建一个延迟调用函数

func (*DelayFunc) Call

func (df *DelayFunc) Call()

Call 执行延迟函数,如果执行失败,抛出异常

func (*DelayFunc) String

func (df *DelayFunc) String() string

String 打印当前延迟函数的信息,用于日志记录

type TimeWheel

type TimeWheel struct {

	// 互斥锁(继承RWMutex的 RWLock,UnLock 等方法)
	sync.RWMutex
	// contains filtered or unexported fields
}

func NewTimeWheel

func NewTimeWheel(name string, interval int64, scales int, maxCap int) *TimeWheel

NewTimeWheel 创建一个时间轮

@name 时间轮的名称
@interval 每个刻度之间的duration时间间隔
@scales 当前时间轮的轮盘一共多少个刻度(如我们正常的时钟就是12个刻度)
@maxCap 每个刻度所最大保存的Timer定时器个数

func (*TimeWheel) AddTimeWheel

func (tw *TimeWheel) AddTimeWheel(next *TimeWheel)

AddTimeWheel 给一个时间轮添加下层时间轮比如给小时时间轮添加分钟时间轮,给分钟时间轮添加秒时间轮

func (*TimeWheel) AddTimer

func (tw *TimeWheel) AddTimer(tid uint32, t *Timer) error

AddTimer 添加一个timer到一个时间轮中(非时间轮自转情况)

func (*TimeWheel) GetTimerWithIn

func (tw *TimeWheel) GetTimerWithIn(duration time.Duration) map[uint32]*Timer

获取定时器在一段时间间隔内的Timer

func (*TimeWheel) RemoveTimer

func (tw *TimeWheel) RemoveTimer(tid uint32)

RemoveTimer 删除一个定时器,根据定时器的id

func (*TimeWheel) Run

func (tw *TimeWheel) Run()

非阻塞的方式让时间轮转起来

type Timer

type Timer struct {
	// contains filtered or unexported fields
}

Timer 定时器实现

func NewTimerAfter

func NewTimerAfter(df *DelayFunc, duration time.Duration) *Timer

NewTimerAfter 创建一个定时器,在当前时间延迟duration之后触发 定时器方法

func NewTimerAt

func NewTimerAt(df *DelayFunc, unixNano int64) *Timer

NewTimerAt 创建一个定时器,在指定的时间触发 定时器方法

@df DelayFunc类型的延迟调用函数类型
@unixNano unix计算机从1970-1-1至今经历的纳秒数

func (*Timer) Run

func (t *Timer) Run()

Run 启动定时器,用一个go承载

type TimerScheduler

type TimerScheduler struct {

	// 互斥锁
	sync.RWMutex
	// contains filtered or unexported fields
}

TimerScheduler 时间轮调度器

依赖模块,delayfunc.go timer.go timewheel.go

func NewAutoExecTimerScheduler

func NewAutoExecTimerScheduler() *TimerScheduler

NewAutoExecTimerScheduler 时间轮定时器,自动调度

func NewTimerScheduler

func NewTimerScheduler() *TimerScheduler

NewTimerScheduler 返回一个定时器调度器

主要创建分层定时器,并做关联,并依次启动

func (*TimerScheduler) CancelTimer

func (this *TimerScheduler) CancelTimer(tid uint32)

删除timer

func (*TimerScheduler) CreateTimerAfter

func (this *TimerScheduler) CreateTimerAfter(df *DelayFunc, duration time.Duration) (uint32, error)

创建一个延迟Timer 并将Timer添加到分层时间轮中, 返回Timer的tid

func (*TimerScheduler) CreateTimerAt

func (this *TimerScheduler) CreateTimerAt(df *DelayFunc, unixNano int64) (uint32, error)

创建一个定点Timer 并将Timer添加到分层时间轮中, 返回Timer的tid

func (*TimerScheduler) GetTriggerChan

func (this *TimerScheduler) GetTriggerChan() chan *DelayFunc

获取计时结束的延迟执行函数通道

func (*TimerScheduler) HasTimer

func (this *TimerScheduler) HasTimer(tid uint32) bool

func (*TimerScheduler) Start

func (this *TimerScheduler) Start()

非阻塞的方式启动timerSchedule

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL