码迷,mamicode.com
首页 > 其他好文 > 详细

一个信号量与定时器的例子(Golang)

时间:2015-02-25 18:39:45      阅读:185      评论:0      收藏:0      [点我收藏+]

标签:go语言   定时器   signal   time.newticker   

        程序可用来定时执行一些任务,并通过信号量处理,在被强制中断时,也能做相应警告及清理处理.  

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

  



一个信号量与定时器的例子(Golang)

标签:go语言   定时器   signal   time.newticker   

原文地址:http://blog.csdn.net/xcl168/article/details/43938765

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!