分享
golang timer
yanbiao · · 2086 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
package main
import (
"fmt"
"time"
)
func main(){
println(time.Now().Unix())
t := time.NewTimer(time.Second*5) //第一次设置
time.Sleep(time.Second*6) //等待超时
//上次t超时所以,t.Reset返回false,t.C 中有第一次设置时的当前时间
if !t.Reset(time.Second*7) {
tt:=<-t.C
fmt.Println(tt.Unix())
}
select {
case tt:=<-t.C:
fmt.Println(tt.Unix())
fmt.Println("what the screte")
}
fmt.Println("hehe")
}
注意在timer超时,t.C中可以获取设置时的当前时间,如果多次执行 <-t.C就会阻塞.
运行结果:
1510046413
1510046418
1510046426
what the screte
hehe
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信2086 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
package main
import (
"fmt"
"time"
)
func main(){
println(time.Now().Unix())
t := time.NewTimer(time.Second*5) //第一次设置
time.Sleep(time.Second*6) //等待超时
//上次t超时所以,t.Reset返回false,t.C 中有第一次设置时的当前时间
if !t.Reset(time.Second*7) {
tt:=<-t.C
fmt.Println(tt.Unix())
}
select {
case tt:=<-t.C:
fmt.Println(tt.Unix())
fmt.Println("what the screte")
}
fmt.Println("hehe")
}
注意在timer超时,t.C中可以获取设置时的当前时间,如果多次执行 <-t.C就会阻塞.
运行结果:
1510046413
1510046418
1510046426
what the screte
hehe