如果协程出现了panic,就会造成程序的崩溃,这时可以在goroutine中使用recover来捕获panic,进行处理,本文就详细的介绍一下,感兴趣的可以了解一下
案例:如果我们起了一个协程,但这个协程出现了panic,但我们没有捕获这个协程,就会造成程序的崩溃,这时可以在goroutine中使用recover来捕获panic,进行处理,这样主线程不会受到影响。
代码如下:
package main import ( "fmt" "time" ) func sayHello() { for i := 0; i < 10; i++ { time.Sleep(time.Second) fmt.Println("hello world") } } func test() { //使用 defer + recover defer func() { //捕获test抛出的panic if err := recover();err!=nil{ fmt.Println("test发生错误",err) } }() //定义一个map var myMap map[int]string myMap[0] = "golang" //error } func main() { go sayHello() go test() for i := 0; i < 10; i++ { fmt.Println("main() ok=",i) time.Sleep(time.Second) } }
执行结果如下图:
到此这篇关于Go语言使用defer+recover解决panic导致程序崩溃的问题的文章就介绍到这了,更多相关Go panic程序崩溃内容请搜索北冥有鱼以前的文章或继续浏览下面的相关文章希望大家以后多多支持北冥有鱼!
您可能感兴趣的文章:
- Go中defer使用场景及注意事项
- C++实现Go的defer功能(示例代码)
- 聊聊golang中多个defer的执行顺序
- Go语言defer语句的三种机制整理
- Go程序员踩过的defer坑错误处理