Go提供了两个内置函数 panic()和recover()用于异常处理。
Go中,对异常处理的整体原则是:多用errors包,少用panic。
对于可预见的错误,比如网络连接失败等,一般都使用errors,只有重大错误才会使用panic。
记住一个大原则:panic会导致程序直接挂掉,除非调用了recover方法。
在函数内部调用 panic 会立即终止当前函数的执行,由当前调用栈逐层返回,一直到最顶层的 main 函数或是被某一层的 recover 捕捉到。
抛出一个panic
import "fmt"
func DoPanic(){
panic("抛出异常")
}
func main() {
fmt.Println("开始")
DoPanic()
fmt.Println("结束")
}
---------------------------
开始
panic: 抛出异常
从Panic中恢复
import "fmt"
func DoPanic(){
//recover用于恢复,使主进程后续程序还能正常运行
defer func(){
recover()
}()
panic("抛出异常")
}
func main() {
fmt.Println("开始")
DoPanic()
fmt.Println("结束")
}
-----------------------------------------------------
开始
结束
recover的错误使用
import "fmt"
func DoRecover(){
defer func(){
recover()
}()
}
func DoPanic(){
DoRecover()
panic("抛出异常")
}
func main() {
fmt.Println("开始")
DoPanic()
fmt.Println("结束")
}
----------------------------
开始
panic: 抛出异常
以上的调用方式没有捕获到异常,recover()
的调用仅当它在defer
函数中被直接调用时才有效。