go笔记-goroutine和panic

目录


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

输出:
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。
上一篇:defer的用法


下一篇:golang操作数据库