部分文章内容为公开资料查询整理,原文出处可能未标注,如有侵权,请联系我,谢谢。邮箱地址:gnivor@163.com ►►►需要气球么?请点击我吧!

go笔记-goroutine和panic


版权声明:本文为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)
}

输出:

最后输出了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实现高并发有一些规范开发必须要注意,否则很容易带来困扰

  1. Golang主程序必须要等待所有的Goroutine结束才能够退出,否则如果先退出主程序会导致所有的Goroutine可能未执行结束就退出了
  2. 每个Goroutine都要有recover机制,因为当一个Goroutine抛panic的时候只有自身能够捕捉到其它Goroutine是没有办法捕捉的。如果没有recover机制,整个进程会crash。
  3. recover只能在defer里面生效,如果不是在defer里调用,会直接返回nil。
  4. Goroutine发生panic时,只会调用自身的defer,所以即便主Goroutine里写了recover逻辑,也无法recover。
posted @ 2021-07-19 10:55  流了个火  阅读(522)  评论(0编辑  收藏  举报
►►►需要气球么?请点击我吧!►►►
View My Stats