版权声明:本文为CSDN博主「玄苦大师233」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/chenguolinblog/article/details/90665080
参考资料:https://draveness.me/golang/docs/part2-foundation/ch05-keyword/golang-panic-recover/


三. 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)
}

输出:
go笔记-goroutine和panic
最后输出了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)
}

则输出
go笔记-goroutine和panic
没有输出 process end, 表明程序已经crash

四. 规范

使用Goroutine实现高并发有一些规范开发必须要注意,否则很容易带来困扰

  1. Golang主程序必须要等待所有的Goroutine结束才能够退出,否则如果先退出主程序会导致所有的Goroutine可能未执行结束就退出了
  2. 每个Goroutine都要有recover机制,因为当一个Goroutine抛panic的时候只有自身能够捕捉到其它Goroutine是没有办法捕捉的。如果没有recover机制,整个进程会crash。
  3. recover只能在defer里面生效,如果不是在defer里调用,会直接返回nil。
  4. Goroutine发生panic时,只会调用自身的defer,所以即便主Goroutine里写了recover逻辑,也无法recover。

相关文章:

  • 2022-02-23
  • 2021-07-26
  • 2018-02-03
  • 2022-12-23
  • 2022-12-23
  • 2021-04-21
  • 2022-12-23
  • 2022-01-16
猜你喜欢
  • 2021-08-08
  • 2022-01-28
  • 2022-01-15
  • 2022-12-23
  • 2021-09-29
  • 2021-05-26
  • 2021-10-09
相关资源
相似解决方案