func test() {num1 := 10num2 := 0result := num1 / num2fmt.Println("result", result)}
func main() {test()for {fmt.Println("运行完毕! main 下面的代码")time.Sleep(time.Second)}}
- 在默认情况下,当发生错误后(panic) ,程序就会退出(崩溃.)
- 如果我们希望:当发生错误后,可以捕获到错误,并进行处理,保证程序可以继续执行。还可
以在捕获到错误后,给管理员一个提示(邮件,短信。。。) - 这里引出我们要将的错误处理机制
基本说明
- Go 语言追求简洁优雅,所以,Go 语言不支持传统的 try…catch…finally 这种处理。
- Go 中引入的处理方式为:defer, panic, recover
- 这几个异常的使用场景可以这么简单描述:Go 中可以抛出一个 panic 的异常,然后在 defer 中
通过 recover 捕获这个异常,然后正常处理
使用 defer+recover 来处理错误
func test() {defer func() {err := recover()if err != nil {fmt.Println("错误信息:", err)}}()num1 := 10num2 := 0result := num1 / num2fmt.Println("result", result)}
func main() {test()for {fmt.Println("运行完毕! main 下面的代码")time.Sleep(time.Second)}}
进行错误处理后,程序不会轻易挂掉,如果加入预警代码,就可以让程序更加的健壮。看一个
案例演示:
自定义错误
自定义错误的介绍
Go 程序中,也支持自定义错误, 使用 errors.New 和 panic 内置函数。
- errors.New(“错误说明”) , 会返回一个 error 类型的值,表示一个错误
- panic 内置函数 ,接收一个 interface{}类型的值(也就是任何值了)作为参数。可以接收 error 类
型的变量, 输出错误信息, 并退出程序.
案例说明
package mainimport ("errors""fmt""time"
)func main() {Test2()for {fmt.Println("运行完毕! main 下面的代码")time.Sleep(time.Second)}}// 读取文件,传入的参数名称错误返回一个自定义的错误
func ReadConfig(f string) (err error) {if f == "Config.init" {fmt.Println("读取文件成功!")return nil} else {return errors.New("文件名不是Config.init")}
}func Test2() {err := ReadConfig("Config.init00")if err != nil {panic("取出文件错误。。。")fmt.Println("终止运行了!")} else {fmt.Println("Test2 继续执行")}
}
正确文件