golang定时器使用示例

1.定时器创建与停止

Go 复制代码
//定时器使用
	t1 := time.NewTimer(2 * time.Second)
	<-t1.C
	fmt.Println("timer1 fired")
	t2 := time.NewTimer(5 * time.Second)
	go func() {
		fmt.Println("go协程处理中,等待5秒后输出...")
		<-t2.C
		fmt.Println("timer2 fired")
	}()
	fmt.Println("主线程等待10秒...")
	t2Stop := t2.Stop() //停止定时器
	if t2Stop {
		fmt.Println("t2定时器已停止...", t2Stop)
	}
	time.Sleep(time.Second * 10)
	fmt.Println("完成")

输出:

bash 复制代码
timer1 fired
主线程等待10秒...
t2定时器已停止... true
go协程处理中,等待5秒后输出...
完成

2.定时器配合协程使用

Go 复制代码
tick := time.NewTicker(500 * time.Millisecond) //500毫秒
	timeEnd := make(chan bool)                     //结束通道
	//协程
	go func() {
		//循环
		for {
			//随机执行任务
			select {
			case <-timeEnd: //结束任务
				fmt.Println("===结束任务")
				return
			case t := <-tick.C: //超时任务
				fmt.Println("==500毫秒响应一次:", t)
			}
		}
	}()
	time.Sleep(5000 * time.Millisecond) //休眠5秒
	tick.Stop()                         //停止定时器
	timeEnd <- true                     //设置结束标志
	fmt.Println("===定时任务结束===")

输出:

bash 复制代码
==500毫秒响应一次: 2024-06-07 11:27:28.4894537 +0800 CST m=+17.528309301
==500毫秒响应一次: 2024-06-07 11:27:28.9967727 +0800 CST m=+18.035628301
==500毫秒响应一次: 2024-06-07 11:27:29.4893206 +0800 CST m=+18.528176201
==500毫秒响应一次: 2024-06-07 11:27:29.9896915 +0800 CST m=+19.028547101
==500毫秒响应一次: 2024-06-07 11:27:30.4901046 +0800 CST m=+19.528960201
==500毫秒响应一次: 2024-06-07 11:27:30.9907067 +0800 CST m=+20.029562301
==500毫秒响应一次: 2024-06-07 11:27:31.4951615 +0800 CST m=+20.534017101
==500毫秒响应一次: 2024-06-07 11:27:32.0016405 +0800 CST m=+21.040496101
==500毫秒响应一次: 2024-06-07 11:27:32.497787 +0800 CST m=+21.536642601
==500毫秒响应一次: 2024-06-07 11:27:32.9988599 +0800 CST m=+22.037715501
===结束任务
===定时任务结束===
相关推荐
豐儀麟阁贵4 分钟前
8.5在方法中抛出异常
java·开发语言·前端·算法
zengyuhan50334 分钟前
Windows BLE 开发指南(Rust windows-rs)
前端·rust
醉方休37 分钟前
Webpack loader 的执行机制
前端·webpack·rust
HalvmånEver42 分钟前
Linux:进程的切换与调度(进程四)
linux·运维·服务器
前端老宋Running1 小时前
一次从“卡顿地狱”到“丝般顺滑”的 React 搜索优化实战
前端·react.js·掘金日报
隔壁的大叔1 小时前
如何自己构建一个Markdown增量渲染器
前端·javascript
用户4445543654261 小时前
Android的自定义View
前端
WILLF1 小时前
HTML iframe 标签
前端·javascript
枫,为落叶1 小时前
Axios使用教程(一)
前端
小章鱼学前端1 小时前
2025 年最新 Fabric.js 实战:一个完整可上线的图片选区标注组件(含全部源码).
前端·vue.js