golang定时器和超时的使用详解

【字号: 作者:雯心浏览:32日期:2022-08-28

我就废话不多说了,大家还是直接看代码吧~

func main() { var a chan string a =make(chan string) go sendDataTo(a) go timing() getAchan(10*time.Second,a)}func sendDataTo(a chan string) { for { a <- '我是a通道的数据' time.Sleep(1e9 *3) }}//在一定时间内接收不到a的数据则超时func getAchan(timeout time.Duration, a chan string) { var after <-chan time.Time loop: after = time.After(timeout) for{ fmt.Println('等待a中的数据,10秒后没有数据则超时') select { case x :=<- a: fmt.Println(x) goto loop case <-after: fmt.Println('timeout.') return } }}func timing() { //定时器,10秒钟执行一次 ticker := time.NewTicker(10 * time.Second) for { time := <-ticker.C fmt.Println('定时器====>',time.String()) }}

补充:golang的定时器NewTimer、NewTicker使用

废话不多说,直接看代码

package main import ( 'fmt' 'sync' 'time') /***ticker只要定义完成,从此刻开始计时,不需要任何其他的操作,每隔固定时间都会触发。*timer定时器,是到固定时间后会执行一次*如果timer定时器要每隔间隔的时间执行,实现ticker的效果,使用 func (t *Timer) Reset(d Duration) bool */func main() { var wg sync.WaitGroup wg.Add(2) //NewTimer 创建一个 Timer,它会在最少过去时间段 d 后到期,向其自身的 C 字段发送当时的时间 timer1 := time.NewTimer(2 * time.Second) //NewTicker 返回一个新的 Ticker,该 Ticker 包含一个通道字段,并会每隔时间段 d 就向该通道发送当时的时间。它会调 //整时间间隔或者丢弃 tick 信息以适应反应慢的接收者。如果d <= 0会触发panic。关闭该 Ticker 可 //以释放相关资源。 ticker1 := time.NewTicker(2 * time.Second) go func(t *time.Ticker) { defer wg.Done() for { <-t.C fmt.Println('get ticker1', time.Now().Format('2006-01-02 15:04:05')) } }(ticker1) go func(t *time.Timer) { defer wg.Done() for { <-t.C fmt.Println('get timer', time.Now().Format('2006-01-02 15:04:05')) //Reset 使 t 重新开始计时,(本方法返回后再)等待时间段 d 过去后到期。如果调用时t //还在等待中会返回真;如果 t已经到期或者被停止了会返回假。 t.Reset(2 * time.Second) } }(timer1) wg.Wait()}

运行结果:

get ticker1 2018-09-07 22:44:29

get timer 2018-09-07 22:44:29

...

额外说明:

time.NewTicker定时触发执行任务,当下一次执行到来而当前任务还没有执行结束时,会等待当前任务执行完毕后再执行下一次任务。查阅go官网的文档和经过代码验证。

time.NewTimer和Reset()函数实现定时触发,Reset()函数可能失败,经测试。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持乐呵呵网。如有错误或未考虑完全的地方,望不吝赐教。

标签: Golang
相关文章: