• ticker定时器:


    Ticker是周期性定时器,即周期性的触发一个事件,通过Ticker本身提供的管道将事件传递出去。

    定时聚合任务

    有时,我们希望把一些任务打包进行批量处理。比如,公交车发车场景:

    • 公交车每隔5分钟发一班,不管是否已坐满乘客;

    • 已坐满乘客情况下,不足5分钟也发车;

    下面代码演示公交车发车场景:

    // TickerLaunch用于演示ticker聚合任务用法
    func TickerLaunch() {
      ticker := time.NewTicker(5 * time.Minute)
      maxPassenger := 30 // 每车最大装载人数
      passengers := make([]string, 0, maxPassenger)
     
      for {
        passenger := GetNewPassenger() // 获取一个新乘客
        if passenger != "" {
          passengers = append(passengers, passenger)
        } else {
        time.Sleep(1 * time.Second)
      }
     
      select {
      case <- ticker.C: // 时间到,发车
        Launch(passengers)
        passengers = []string{}
      default:
        if len(passengers) >= maxPassenger { // 时间没到,车已座满,发车
          Launch(passengers)
          passengers = []string{}
        }
      }
      }
    }
    上面代码中for循环负责接待乘客上车,并决定是否要发车。每当乘客上车,select语句会先判断ticker.C中是否有数据,有数据则代表发车时间已到,如果没有数据,则判断车是否已坐满,坐满后仍然发车。
    总结

    Ticker相关内容总结如下:

    • 使用time.NewTicker()来创建一个定时器;

    • 使用Stop()来停止一个定时器;

    • 定时器使用完毕要释放,否则会产生资源泄露;

  • 相关阅读:
    责任链模式(Chain)
    适配器模式(Adapter)
    为什么你不应该读大学
    【JMedia】诺贝尔奖得主:东亚教育浪费了太多生命
    用IDEA/WebStrom 提交本地项目到Git/码云等
    requireJs 踩的坑
    pjax 笔记
    PHP 环境搭建及zabbix安装遇到的一些坑.
    div流加载
    spring data jpa 学习笔记
  • 原文地址:https://www.cnblogs.com/smallleiit/p/12482416.html
Copyright © 2020-2023  润新知