【go】延迟执行和定时器实现

目录

time.Sleep

time.After

time.NewTimer

time.NewTicker


time.Sleep

time.Sleep可以实现延时执行

Go 复制代码
func TestSleep(t *testing.T) {
	fmt.Println("start time:", time.Now().Format("2006-01-02 15:04:05.000"))

	time.Sleep(2 * time.Second)

	fmt.Println("end   time:", time.Now().Format("2006-01-02 15:04:05.000"))
}

time.After

time.After也可以实现延迟执行。返回一个只读的time.Time类型的channel,读取到的是延迟后的当前时间

Go 复制代码
func TestAfter(t *testing.T) {
	fmt.Println("start time:", time.Now().Format("2006-01-02 15:04:05.000"))

	var timer <-chan time.Time = time.After(2 * time.Second)
	now := <-timer

	fmt.Println("end   time:", now.Format("2006-01-02 15:04:05.000"))
}

time.NewTimer

time.NewTimer可以实现延迟执行,并且还提供了重置延迟时间的接口实现定时器。timer.C返回的是一个只读的time.Time类型的channel,读取到的是延迟后的当前时间

Go 复制代码
func TestTimer(t *testing.T) {
	fmt.Println("start time:", time.Now().Format("2006-01-02 15:04:05.000"))

	var timer *time.Timer = time.NewTimer(2 * time.Second)

	for now := range timer.C {
		timer.Reset(3 * time.Second)
		fmt.Println("now   time:", now.Format("2006-01-02 15:04:05.000"))
	}
}

time.NewTicker

time.NewTicker直接实现了定时器。

Go 复制代码
func TestTicker(t *testing.T) {
	fmt.Println("start time:", time.Now().Format("2006-01-02 15:04:05.000"))

	ticker := time.NewTicker(2 * time.Second)

	for now := range ticker.C {
		fmt.Println("now   time:", now.Format("2006-01-02 15:04:05.000"))
	}
}
相关推荐
天天向上10248 小时前
go 配置热更新
开发语言·后端·golang
Asus.Blogs10 小时前
SSE + Resty + Goroutine + Channel 完整学习笔记
笔记·学习·golang
赴前尘11 小时前
golang获取一个系统中没有被占用的端口
开发语言·后端·golang
sandyznb12 小时前
go面试汇总
开发语言·面试·golang
ChineHe15 小时前
Gin框架基础篇004_中间件的使用与机制详解
后端·golang·gin
serendipity_hky15 小时前
【go语言 | 第6篇】Go Modules 依赖解决
开发语言·后端·golang
吴佳浩 Alben15 小时前
Go 1.25.5 通关讲解
开发语言·后端·golang
小高Baby@16 小时前
深入理解golang的GMP模型
开发语言·后端·golang
Grassto16 小时前
一个 import 语句,引发的 Go 第三方包加载之旅
golang·go·go module
天远云服16 小时前
Go 语言实战:手撸 AES-128-CBC 加密,对接天远金融风控 API
大数据·服务器·网络·golang