分享
一个信号量与定时器的例子(Golang)
xcltapestry · · 3316 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
程序可用来定时执行一些任务,并通过信号量处理,在被强制中断时,也能做相应警告及清理处理.
package main
//信号量与定时器
//author: Xiong Chuan Liang
//date: 2015年2月25日
import "fmt"
import "os"
import "os/signal"
import "time"
func main() {
sigs := make(chan os.Signal, 1)
done := make(chan bool, 1)
signal.Notify(sigs, os.Interrupt, os.Kill)
go func() {
sig := <-sigs
switch sig {
case os.Interrupt:
fmt.Println("signal: Interrupt")
case os.Kill:
fmt.Println("signal: Kill")
default:
fmt.Println("signal: Others")
}
done <- true
}()
fmt.Println("awaiting signal")
//main()....
go JobTicker(done)
<-done
close(done)
//app.Exit()
fmt.Println("exiting")
}
func JobTicker(done <-chan bool) {
ticker := time.NewTicker(time.Second)
defer ticker.Stop()
for {
select {
case <-done:
return
case <-ticker.C:
fmt.Println("job......")
}
}
}
如果按 ctrl-C 则结果如下:
awaiting signal job...... job...... signal: Interrupt interrupt exiting
Go by Example: Signals: https://gobyexample.com/signals
MAIL: xcl_168@aliyun.com
Blog: http://blog.csdn.net/xcl168
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信3316 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
程序可用来定时执行一些任务,并通过信号量处理,在被强制中断时,也能做相应警告及清理处理.
package main
//信号量与定时器
//author: Xiong Chuan Liang
//date: 2015年2月25日
import "fmt"
import "os"
import "os/signal"
import "time"
func main() {
sigs := make(chan os.Signal, 1)
done := make(chan bool, 1)
signal.Notify(sigs, os.Interrupt, os.Kill)
go func() {
sig := <-sigs
switch sig {
case os.Interrupt:
fmt.Println("signal: Interrupt")
case os.Kill:
fmt.Println("signal: Kill")
default:
fmt.Println("signal: Others")
}
done <- true
}()
fmt.Println("awaiting signal")
//main()....
go JobTicker(done)
<-done
close(done)
//app.Exit()
fmt.Println("exiting")
}
func JobTicker(done <-chan bool) {
ticker := time.NewTicker(time.Second)
defer ticker.Stop()
for {
select {
case <-done:
return
case <-ticker.C:
fmt.Println("job......")
}
}
}
如果按 ctrl-C 则结果如下:
awaiting signal job...... job...... signal: Interrupt interrupt exiting
Go by Example: Signals: https://gobyexample.com/signals
MAIL: xcl_168@aliyun.com
Blog: http://blog.csdn.net/xcl168