概念简介
有时候,我们希望 Go 能智能的处理 Unix 信号。
例如,我们希望当服务器接收到一个 `SIGTERM` 信号时能够
自动关机,或者一个命令行工具在接收到一个 `SIGINT` 信号
时停止处理输入信息。这里讲的就是在 Go 中如何通过通道
来处理信号。
例程代码
package main
import "fmt"
import "os"
import "os/signal"
import "syscall"
func main() {
// Go 通过向一个通道发送 `os.Signal` 值来进行信号通知。我们
// 将创建一个通道来接收这些通知(同时还创建一个用于在程序可
// 以结束时进行通知的通道)。
sigs := make(chan os.Signal, 1)
done := make(chan bool, 1)
// `signal.Notify` 注册这个给定的通道用于接收特定信号。
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
// 这个 Go 协程执行一个阻塞的信号接收操作。当它得到一个
// 值时,它将打印这个值,然后通知程序可以退出。
go func() {
sig := <-sigs
fmt.Println()
fmt.Println(sig)
done <- true
}()
// 程序将在这里进行等待,直到它得到了期望的信号(也就
// 是上面的 Go 协程发送的 `done` 值)然后退出。
fmt.Println("awaiting signal")
<-done
fmt.Println("exiting")
}
执行&输出
# 当我们运行这个程序时,它将一直等待一个信号。使用 `ctrl-C`
# (终端显示为 `^C`),我们可以发送一个 `SIGINT` 信号,这会
# 使程序打印 `interrupt` 然后退出。
$ go run signals.go
awaiting signal
^C
interrupt
exiting
课程导航
学习上一篇Go语言教程:执行进程 学习下一篇Go语言教程:Exit
相关资料
本例程github源代码:https://github.com/xg-wang/gobyexample/tree/master/examples/signals