Golang 有2个内置的函数 panic()
和 recover()
,用以报告和捕获运行时发生的程序错误,与 error 不同,panic-recover 一般用在函数内部。一定要注意不要滥用 panic-recover,可能会导致性能问题,我一般只在未知输入和不可靠请求时使用。
golang 的错误处理流程:当一个函数在执行过程中出现了异常或遇到 panic()
,正常语句就会立即终止,然后执行 defer 语句,再报告异常信息,最后退出 goroutine。如果在 defer 中使用了 recover() 函数,则会捕获错误信息,使该错误信息终止报告。
看代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
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$
看代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
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$
好好体会下。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/stpeace/article/details/82902640