go语言的panic和recover函数用法实例

Kitty ·
更新时间:2024-11-10
· 823 次阅读

Golang 有2个内置的函数 panic()recover(),用以报告和捕获运行时发生的程序错误,与 error 不同,panic-recover 一般用在函数内部。一定要注意不要滥用 panic-recover,可能会导致性能问题,我一般只在未知输入和不可靠请求时使用。

golang 的错误处理流程:当一个函数在执行过程中出现了异常或遇到 panic(),正常语句就会立即终止,然后执行 defer 语句,再报告异常信息,最后退出 goroutine。如果在 defer 中使用了 recover() 函数,则会捕获错误信息,使该错误信息终止报告。

看代码:

package main import "fmt" func main(){ defer func(){ fmt.Println("c") // if err := recover(); err != nil{ // fmt.Println(err) // }else{ // fmt.Println("hehe") // } // if err := recover(); err != nil{ // fmt.Println(err) // }else{ // fmt.Println("haha") // } fmt.Println("d") }() f() defer func(){ fmt.Println("e") }() } func f(){ fmt.Println("a") panic(10000) fmt.Println("b") fmt.Println("f") }

结果:

ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
d
panic: 10000
goroutine 1 [running]:
panic(0x4b8480, 0xc82000a2c0)
        /usr/lib/go-1.6/src/runtime/panic.go:481 +0x3e6
main.f()
        /home/ubuntu/taoge/go/test.go:34 +0x115
main.main()
        /home/ubuntu/taoge/go/test.go:25 +0x35
exit status 2
ubuntu@VM-0-15-ubuntu:~/taoge/go$

看代码:

package main import "fmt" func main(){ defer func(){ fmt.Println("c") if err := recover(); err != nil{ fmt.Println(err) }else{ fmt.Println("hehe") } if err := recover(); err != nil{ fmt.Println(err) }else{ fmt.Println("haha") } fmt.Println("d") }() f() defer func(){ fmt.Println("e") }() } func f(){ fmt.Println("a") panic(10000) fmt.Println("b") fmt.Println("f") }

结果:

ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
10000
haha
d
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 

好好体会下。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对软件开发网的支持。如果你想了解更多相关内容请查看下面相关链接

您可能感兴趣的文章:用go gin server来做文件上传服务使用go gin来操作cookie的讲解在go中使用omitempty的代码实例Go语言init函数详解Golang命令行进行debug调试操作go语言匿名函数的使用go各种import的使用方法讲解golang中range在slice和map遍历中的注意事项Golang捕获panic堆栈信息的讲解为什么Go语言把类型声明放在后面?



panic GO go语言

需要 登录 后方可回复, 如果你还没有账号请 注册新账号