错误处理
- 在默认情况下,当发生错误后(panic) ,程序就会退出(崩溃)
- 如果我们希望:当发生错误后,可以捕获到错误,并进行处理,保证程序可以继续执行。还可以在捕获到错误后,给管理员一一个提示(邮件短信…)
- 基本说明
- Go 语言追求简洁优雅,所以,Go 语言不支持传统的 try…cact…finally 这种处理。
- Go 中引入的处理方式为: defer, panic, recover【内置函数】
- 这几个异常的使用场景可以这么简单描述: Go中可以抛出一个 panic 的异常,然
后在 defer 中通过 recover 捕获这个异常,然后正常处理
package main
import (
"fmt"
)
func main() {
test()
fmt.Println("I am here")
}
func test() {
defer func() {
//err := recover()
//if err != nil {
if err := recover(); err != nil {
fmt.Println("err =", err)
}
}()
n1 := 100
n2 := 0
res := n1 / n2
fmt.Println(res)
}
/*
err = runtime error: integer divide by zero
I am here
*/
自定义错误
Go 程序中,也支持自定义错误,使用 errors.New 和 panic 内置函数。
- errors.New(" 错误说明"),会返回一个 error 类型的值,表示一个错误
- panic 内置函数,接收一个 interface{} 类型的值(也就是任何值了)作为参数。可以接收 error 类型的变量,输出错误信息,并退出程序.
当函数发生 panic 时,它会终止运行,在执行完所有的延迟函数后,程序控制返回到该函数的调用方
package main
import (
"errors"
"fmt"
)
func main() {
test()
fmt.Println("I am here")
}
func readConf(name string) (err error) {
if name == "redis.conf" {
return nil
} else {
return errors.New("读取文件错误")
}
}
func test() {
err := readConf("redis.conf1")
if err != nil {
panic(err)
}
fmt.Println("go to continue")
}
/*
panic: 读取文件错误
goroutine 1 [running]:
main.test()
D:/go/src/04/1/main/main.go:26 +0x61
main.main()
D:/go/src/04/1/main/main.go:10 +0x29
*/