GO语言-channel-定时器

513 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第18天,点击查看活动详情

定时器

channel是GO语言中非常核心的机制,定时器的内部很多就是channel实现的。

//创建定时器
func NewTimer(d Duration) *Timer
type Timer struct{
C <-chan Time
 r runtimeTimer
 }
 // 定时器停止
 func (t *Timer) Stop() bool

我们可以先了解一下定时器相关的结构体以及API,Timer是GO语言定时器的结构,它内部的一个重要元素就是C ,这是一个只读的channel。NewTimer构造定时器,Duration代表定时的时刻,在d时间间隔内channel会收到一条Time类型的数据Stop结束定时器。Timer是一个一次性定时器,当收到Time类型后,他就会随着失效。

周期类的定时任务

在GO语言中可以使用Ticker来实现周期类的定时任务

func NewTicker(d Duration)*Ticker
type Ticker struct{
 C <-chan Time
 r runtimeTimer
 }
 //定时器停止
 func (t *Ticker)Stop()

NewTicker负责构造周期性定时器,每个d个时间间隔,就会收到一个Time类型数据。Ticker是周期性定时器结构体,核心依旧是依靠channel来实现。

实例

用定时器来实现一个倒计时的代码,我们可以使用一个周期性定时器来实现定时任务。一下为主要代码


func finish(){
 fmt.Println("结束")
}
func main (){
ticker:=time.NewTicker(Time.Second)
num:=5
for{
  <-ticker.C //读取但无人接收
  fmt.Println(num)
  num--
  if num==0{
  break
  }
  }
  
  ticker.Stop()
  finish()
  }

在实例中使用了一个<-ticker.C 的语句去处理channel,在GO语言中是被允许的。可以不设定变量去接收channel中的数据。我们关心的是channel是否产生了数据,并不关心数据到底是什么。

总结

通过定时器的实现,更加了解了GO语言的特性以及channel的使用以及一些巧妙的使用方法。