func test() {
num1 := 10
num2 := 0
result := num1 / num2
fmt.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 := 10
num2 := 0
result := num1 / num2
fmt.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 main
import (
"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 继续执行")
}
}
正确文件