版权声明:本文为博主原创文章,未经博主允许不得转载。 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来处理错误 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
文章来源: GO语言使用之Error处理