[Go] gocron源码阅读-groutine与channel应用到信号捕获
Posted taoshihan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[Go] gocron源码阅读-groutine与channel应用到信号捕获相关的知识,希望对你有一定的参考价值。
直接使用go 函数名()可以开启一个grountine,channel可以接收信息并且如果没有数据时会阻塞住
channel对应的是底层数据结构的引用,复制channel和函数传参都是拷贝的引用
make的时候第二个参数是1,就表示是有缓存的channel
无缓存的channel也叫同步channel
c = make(chan interface{}) //开启groutine go mySig() //主grountine不能断 for { time.Sleep(time.Second) c <- "taoshihan" } func mySig() { for { str := <-c fmt.Println(str) } }
信号处理使用channel通信
func catchSignal() { c := make(chan os.Signal, 1) signal.Notify(c, syscall.SIGHUP, syscall.SIGINT, syscall.SIGTERM) for { s := <-c logger.Info("收到信号 -- ", s) switch s { case syscall.SIGHUP: logger.Info("收到终端断开信号, 忽略") case syscall.SIGINT, syscall.SIGTERM: shutdown() } } }
完整代码:
package main import ( "fmt" "os" "os/signal" "syscall" "time" ) var c chan interface{} func main() { go catchSignal() c = make(chan interface{}) //开启groutine go mySig() //主grountine不能断 for { time.Sleep(time.Second) c <- "taoshihan" } } func mySig() { for { str := <-c fmt.Println(str) } } func catchSignal() { d := make(chan os.Signal, 1) signal.Notify(d, syscall.SIGHUP, syscall.SIGINT, syscall.SIGTERM) for { s := <-d fmt.Println("收到信号 -- ", s) switch s { case syscall.SIGHUP: fmt.Println("收到终端断开信号, 忽略") case syscall.SIGINT, syscall.SIGTERM: //这里可以做一些退出动作 fmt.Println("关闭") os.Exit(0) } } }
以上是关于[Go] gocron源码阅读-groutine与channel应用到信号捕获的主要内容,如果未能解决你的问题,请参考以下文章
[Go] gocron源码阅读-空接口类型interface{}
[Go] gocron源码阅读-通过第三方cli包实现命令行参数获取和管理
2022-07-18:以下go语言代码输出什么?A:Groutine;B:Main;C:Goroutine;D:GoroutineMain。 package main import ( “f