mirror of
https://github.com/TeaOSLab/EdgeNode.git
synced 2025-11-03 23:20:25 +08:00
优化代码
This commit is contained in:
@@ -63,7 +63,7 @@ func (this *CountryManager) Start() {
|
||||
events.On(events.EventQuit, func() {
|
||||
ticker.Stop()
|
||||
})
|
||||
for range ticker.C {
|
||||
for ticker.Next() {
|
||||
err := this.loop()
|
||||
if err != nil {
|
||||
remotelogs.ErrorObject("COUNTRY_MANAGER", err)
|
||||
|
||||
@@ -67,7 +67,7 @@ func (this *ProvinceManager) Start() {
|
||||
events.On(events.EventQuit, func() {
|
||||
ticker.Stop()
|
||||
})
|
||||
for range ticker.C {
|
||||
for ticker.Next() {
|
||||
err := this.loop()
|
||||
if err != nil {
|
||||
remotelogs.ErrorObject("PROVINCE_MANAGER", err)
|
||||
|
||||
@@ -1,47 +1,43 @@
|
||||
package utils
|
||||
|
||||
import (
|
||||
"sync"
|
||||
"time"
|
||||
)
|
||||
|
||||
// 类似于time.Ticker,但能够真正地停止
|
||||
// Ticker 类似于time.Ticker,但能够真正地停止
|
||||
type Ticker struct {
|
||||
raw *time.Ticker
|
||||
raw *time.Ticker
|
||||
done chan bool
|
||||
once sync.Once
|
||||
|
||||
S chan bool
|
||||
C <-chan time.Time
|
||||
|
||||
isStopped bool
|
||||
}
|
||||
|
||||
// 创建新Ticker
|
||||
// NewTicker 创建新Ticker
|
||||
func NewTicker(duration time.Duration) *Ticker {
|
||||
raw := time.NewTicker(duration)
|
||||
return &Ticker{
|
||||
raw: raw,
|
||||
C: raw.C,
|
||||
S: make(chan bool, 1),
|
||||
raw: raw,
|
||||
C: raw.C,
|
||||
done: make(chan bool, 1),
|
||||
}
|
||||
}
|
||||
|
||||
// 查找下一个Tick
|
||||
// Next 查找下一个Tick
|
||||
func (this *Ticker) Next() bool {
|
||||
select {
|
||||
case <-this.raw.C:
|
||||
return true
|
||||
case <-this.S:
|
||||
case <-this.done:
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
// 停止
|
||||
// Stop 停止
|
||||
func (this *Ticker) Stop() {
|
||||
if this.isStopped {
|
||||
return
|
||||
}
|
||||
|
||||
this.isStopped = true
|
||||
|
||||
this.raw.Stop()
|
||||
this.S <- true
|
||||
this.once.Do(func() {
|
||||
this.raw.Stop()
|
||||
this.done <- true
|
||||
})
|
||||
}
|
||||
|
||||
@@ -41,9 +41,9 @@ func TestTicker2(t *testing.T) {
|
||||
for {
|
||||
t.Log("loop")
|
||||
select {
|
||||
case <-ticker.C:
|
||||
case <-ticker.raw.C:
|
||||
t.Log("tick")
|
||||
case <-ticker.S:
|
||||
case <-ticker.done:
|
||||
return
|
||||
}
|
||||
}
|
||||
@@ -63,3 +63,17 @@ func TestTickerEvery(t *testing.T) {
|
||||
})
|
||||
wg.Wait()
|
||||
}
|
||||
|
||||
|
||||
func TestTicker_StopTwice(t *testing.T) {
|
||||
ticker := NewTicker(3 * time.Second)
|
||||
go func() {
|
||||
time.Sleep(10 * time.Second)
|
||||
ticker.Stop()
|
||||
ticker.Stop()
|
||||
}()
|
||||
for ticker.Next() {
|
||||
t.Log("tick")
|
||||
}
|
||||
t.Log("finished")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user