版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/TDCQZD/article/details/82682319
一、为什么需要处理错误?
1、从案列引出error处理
package main
import (
"fmt"
)
func test() {
num1 := 10
num2 := 0
res := num1 / num2
fmt.Println("res=", res)
}
func main() {
test()
fmt.Println("下面的代码和逻辑...")
}
案列分析:
代码因为执行到 num/0 的因此发生了 panic : runtime error 导致整个程序崩溃. 但是在实际开发中,我们希望:如果出现panic, 给管理员一个预警,但是程序还执行.-> 错误处理机制。
2、错误处理的好处
进行错误处理后,程序不会轻易挂掉,如果加入预警代码,就可以让程序更加的健壮。
二、基本介绍
1、Go语言追求简洁优雅,所以,Go语言不支持传统的 try…catch…finally 这种处理。
2、Go中引入的处理方式为:defer, panic, recover
3、这几个异常的使用场景可以这么简单描述:Go中可以抛出一个panic的异常,然后在defer中通过recover捕获这个异常,然后处理
三、使用defer 和 recover来处理错误
// 使用defer 和 recover来处理错误
func ErrorDemo() (errCount int){
defer func() {
if err := recover(); err != nil {
//说明err有错误
fmt.Println("发送短信,邮件给管理员...", err)
errCount++
}
}()
num1 := 10
num2 := 0
res := num1 / num2
fmt.Println("res=", res)
return
}
四、自定义错误
Go程序中,也支持自定义错误, 使用errors.New 和 panic 内置函数。
1、errors.New(“错误说明”) , 会返回一个error类型的值,表示一个错误
2、panic内置函数 ,接收一个interface{}类型的值(也就是任何值了)作为参数。可以接收error类型的变量,输出错误信息,并退出程序.
// 自定义错误
func ErrorDemo2() {
// 测试的panic 是否会被捕获
defer func() {
err := recover() // 程序不会崩溃
fmt.Println("test defer err=", err)
}()
err := readConfig("config2.ini")
if err != nil {
//我们以后的代码,需要去判断到底是什么错误类型,然后给予不同的处理机制
if err == FILE_NOT_EXIST {
fmt.Println("错误为FILE_NOT_EXIST , 处理方式为...", err)
// 如果你希望发生了 FILE_NOT_EXIST, 你认为这个错误是致命,你希望抛出错误,并
// 退出程序,就使用panic 完成(前提是你没有 defer + recover 处理)
panic(err)
} else if err == FILE_IO_ERROR {
fmt.Println("错误为FILE_IO_ERROR , 处理方式为...", FILE_NOT_EXIST)
}
//fmt.Println("readconfig err=", err)
} else {
fmt.Println("success")
}
}
func readConfig(fileName string) (err error) {
//假设我们要求这个文件名必须 config.ini , 抛出一个错误
if fileName == "config.ini" {
return nil // 没错
} else {
//返回一个自定义的异常
//return errors.New("file not exist")
return FILE_NOT_EXIST
}
}
五、go项目中处理Error