原文来源于:https://www.yii666.com/blog/328853.html
原标题:go中的错误处理(一)——error类型介绍和使用
前言错误处理是所有编程语言都需要面对的一个问题,golang中,对待普通的错误通常使用error类型+返回值进行处理,对待更严重的错误,通常使用panic和recover进行处理。在本文中,着重于error类型的相关处理操作。文章来源地址https://www.yii666.com/blog/328853.html
error类型error类型是Golang内置类型之一,其本质上只是一个接口,所以只要实现了这个接口,就可以是error类型了,后续自定义错误类型就是这个原理:
type error interface {
Error() string
}
Go 语言内置了一个 errors 包,可以用来创建和处理错误。可以使用 errors.New() 函数创建一个简单的错误,如下所示:文章来源地址:https://www.yii666.com/blog/328853.html
package main
import (
"errors"
"fmt"
)
func divide(a, b int) (int, error) {
if b == 0 {
return 0, errors.New("division by zero")
}
return a / b, nil
}
func main() {
result, err := divide(10, 0)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(result)
}
errors.New()
自定义错误类型
errors.New()
package main
import (
"fmt"
)
type DivideError struct {
dividend int
divisor int
}
func NewDivideError(a,b int)*DivideError {
return &DivideError{dividend: a,divisor: b}
}
func (e *DivideError) Error() string {
return fmt.Sprintf("cannot divide %d by %d", e.dividend, e.divisor)
}
func divide(a, b int) (int, error) {
if b == 0 {
return 0, NewDivideError(a,b)
}
return a / b, nil
}
func main() {
result, err := divide(10, 0)
if err != nil {
if e, ok := err.(*DivideError); ok {
fmt.Println("Divide error:", e)
return
}
fmt.Println(err)
return
}
fmt.Println(result)
}
DivideError
错误处理
if
我们还可以使用defer来进行辅助进行错误的处理及清理资源,如在退出前关闭文件、数据库操作、锁等等,关于文件的操作例子如下:
func readFile(filename string) (string, error) {
f, err := os.Open(filename)
if err != nil {
return "", err
}
defer f.Close()
content, err := ioutil.ReadAll(f)
if err != nil {
return "", err
}
return string(content), nil
}
注意,defer的运行顺序是类似栈的顺序,即先进后出。
总结总的来说,GO的错误处理是比较轻量的,使用error类型即可处理大部分的错误了。但是还有一些极端严重的错误需要使用panic和recover来进行处理,下篇文章会进行分析。