go的Ticker,Timer,Tick的区别和用法

2023-11-01 05:28
文章标签 go 用法 区别 tick timer ticker

本文主要是介绍go的Ticker,Timer,Tick的区别和用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面

在go面试的时候,面试官经常会问time包的Ticker,Timer以及Tick的区别,一般在超时控制的时候用的比较多。今天就来详细学一下这几个的区别
Ticker
Ticker是周期性定时器,即周期性的触发一个事件,它会以一个间隔(interval)往channel发送一个事件(当前时间),而channel的接收者可以以固定的时间间隔从channel中读取事件。通过Ticker本身提供的管道将事件传递出去
示例
css复制代码

func main() {t1 := time.NewTicker(3 * time.Second)defer t1.Stop()for {select {case <-t1.C:fmt.Printf("%s\n", time.Now())}}
}

结果
ini复制代码

2023-10-21 18:53:30.629901 +0800 CST m=+3.001061072
2023-10-21 18:53:33.629444 +0800 CST m=+6.000526969
2023-10-21 18:53:36.629429 +0800 CST m=+9.000436237

通过NewTicker创建一个Ticker,然后通过通过for+select实现定时执行。记住Ticker一定要调用Stop方法,关闭chan,否则容易造成内存泄露。Ticker最常用的2个函数就是NewTicker和Stop。
Ticker主要用于定期循环执行某一个操作。
Timer
用于执行一次性任务。在指定时间间隔之后再下chan发送一个事件(当前时间)

func main() {t1 := time.NewTimer(3 * time.Second)defer t1.Stop()for {t1.Reset(3 * time.Second)select {case <-t1.C:fmt.Printf("%s\n", time.Now())}}
}

用Timer也能实现Ticker循环执行的功能,但是每次必须调用Reset方法,否则会死锁,因为Timer只会执行一次。不过Timer一般不用于循环执行,它用于超时控制,比如调用某个rpc,如果超过3s则终止调用。
示例

func main() {t1 := time.NewTimer(3 * time.Second)defer t1.Stop()ctx, cancel := mockRPC()select {case <-ctx.Done():fmt.Printf("rpc end\n")breakcase <-t1.C:// t1时间到了,rpc还没执行完,则执行cancel()并退出fmt.Printf("%s\n", time.Now())cancel()}
}

// mockRPC. 异步执行5s钟,如果已经结束了则停止执行

func mockRPC() (context.Context, context.CancelFunc) {ctx, cancel := context.WithCancel(context.Background())go func() {for i := 0; i < 5; i++ {select {case <-ctx.Done():breakdefault:fmt.Printf("%d\n", i)time.Sleep(time.Second)}}}()return ctx, cancel
}

结果
ini复制代码0
1
2
2023-10-21 19:18:53.565153 +0800 CST m=+3.000558307

Tick
Tick其实最简单,直接看它的源代码

func Tick(d Duration) <-chan Time {if d <= 0 {return nil}return NewTicker(d).C
}

发现Tick其实就是一个Ticker的C,所以使用起来更方便

css复制代码func main() {t1 := time.Tick(3 * time.Second)for {select {case <-t1:fmt.Printf("%s\n", time.Now())}}
}

但是有一个问题,由于Tick()函数没有返回Ticker,我们无法关闭它,所以这个t1对应的Ticker用于无法关闭,会造成内存泄露。一般不推荐用Tick,直接使用Ticker就好了。应该只能在程序结束的时候会回收内存,但是Tick和Ticker区别这么小,不知道为什么要定义Tick()这个函数。
总结

Ticker是一个定时器。
Timer是一个延迟执行器,也可以通过Reset()来实现定时器。
Tick()是一个函数,返回Ticker的chan,不推荐使用。

这篇关于go的Ticker,Timer,Tick的区别和用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/320784

相关文章

native和static native区别

本文基于Hello JNI  如有疑惑,请看之前几篇文章。 native 与 static native java中 public native String helloJni();public native static String helloJniStatic();1212 JNI中 JNIEXPORT jstring JNICALL Java_com_test_g

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

bytes.split的用法和注意事项

当然,我很乐意详细介绍 bytes.Split 的用法和注意事项。这个函数是 Go 标准库中 bytes 包的一个重要组成部分,用于分割字节切片。 基本用法 bytes.Split 的函数签名如下: func Split(s, sep []byte) [][]byte s 是要分割的字节切片sep 是用作分隔符的字节切片返回值是一个二维字节切片,包含分割后的结果 基本使用示例: pa

go基础知识归纳总结

无缓冲的 channel 和有缓冲的 channel 的区别? 在 Go 语言中,channel 是用来在 goroutines 之间传递数据的主要机制。它们有两种类型:无缓冲的 channel 和有缓冲的 channel。 无缓冲的 channel 行为:无缓冲的 channel 是一种同步的通信方式,发送和接收必须同时发生。如果一个 goroutine 试图通过无缓冲 channel

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否

javascript中break与continue的区别

在javascript中,break是结束整个循环,break下面的语句不再执行了 for(let i=1;i<=5;i++){if(i===3){break}document.write(i) } 上面的代码中,当i=1时,执行打印输出语句,当i=2时,执行打印输出语句,当i=3时,遇到break了,整个循环就结束了。 执行结果是12 continue语句是停止当前循环,返回从头开始。

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们

ActiveMQ—Queue与Topic区别

Queue与Topic区别 转自:http://blog.csdn.net/qq_21033663/article/details/52458305 队列(Queue)和主题(Topic)是JMS支持的两种消息传递模型:         1、点对点(point-to-point,简称PTP)Queue消息传递模型:         通过该消息传递模型,一个应用程序(即消息生产者)可以