版权声明:本文为CSDN博主「玄苦大师233」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/chenguolinblog/article/details/90665080
三. Recover
虽然Goroutine能够实现高并发,但是如果某个Goroutine panic了,而且这个Goroutine里面没有捕获recover,那么整个进程就会挂掉。所以,好的习惯是每当go产生一个goroutine,就需要写下recover。
func fun(num int) {
defer func() {
err := recover()
if err != nil {
fmt.Println("recover panic, err:", err)
}
}()
panic("panic error info")
}
func main() {
for i := 0; i < 10; i++ {
idx := i
go fun(idx)
}
time.Sleep(time.Second * 1)
}
输出:
最后输出了process end
如果不recover
func fun(num int) {
panic("panic error info")
}
func main() {
for i := 0; i < 10; i++ {
idx := i
go fun(idx)
}
time.Sleep(time.Second * 1)
}
则输出
没有输出 process end
, 表明程序已经crash
四. 规范
使用Goroutine实现高并发有一些规范开发必须要注意,否则很容易带来困扰
- Golang主程序必须要等待所有的Goroutine结束才能够退出,否则如果先退出主程序会导致所有的Goroutine可能未执行结束就退出了
- 每个Goroutine都要有recover机制,因为当一个Goroutine抛panic的时候只有自身能够捕捉到其它Goroutine是没有办法捕捉的。如果没有recover机制,整个进程会crash。
- recover只能在defer里面生效,如果不是在defer里调用,会直接返回nil。
- Goroutine发生panic时,只会调用自身的defer,所以即便主Goroutine里写了recover逻辑,也无法recover。