go 中自定义错误处理通过自定义错误类型 (e.g. errors.new() ) 能提供更详细的错误信息。可以使用 switch 语句处理不同错误情况,并使用 errors.is() 方便单元测试。自定义错误类型带来更好的错误信息、更方便的处理和单元测试支持。

Go 中函数异常处理的自定义错误类型和处理策略
在 Go 中,我们可以通过使用 error 接口来创建自定义错误类型。自定义错误类型允许我们指定错误的具体信息,从而可以更好地区分不同的错误情况。
自定义错误类型
要创建自定义错误类型,可以使用 errors.New() 函数,该函数返回一个实现了 error 接口的类型为 error 的值。例如,我们可以创建一个表示文件不存在错误的自定义错误类型:
import "errors"
var ErrFileNotExist = errors.New("file not exist")使用自定义错误类型
在函数中使用自定义错误类型时,需要使用 return 语句返回该错误值。例如,在一个打开文件的函数中,如果文件不存在,可以返回 ErrFileNotExist 错误:
立即学习“go语言免费学习笔记(深入)”;
func OpenFile(filename string) (*File, error) {
f, err := os.Open(filename)
if err != nil {
return nil, ErrFileNotExist
}
return f, nil
}处理自定义错误类型
在调用使用自定义错误类型的函数时,我们可以使用 switch 语句来处理不同的错误情况。例如,在调用 OpenFile 函数时,我们可以使用以下代码来处理 ErrFileNotExist 错误:
func main() {
f, err := OpenFile("example.txt")
switch err {
case ErrFileNotExist:
fmt.Println("File not exist")
default:
fmt.Println("Other error:", err)
}
}优点
使用自定义错误类型可以带来以下优点:
- 更好的错误信息:自定义错误类型可以提供更详细和有意义的错误信息。
- 更方便的错误处理:我们可以使用
switch语句来方便地处理不同的错误情况。 - 单元测试:我们可以使用
errors.Is()函数来更方便地对错误进行单元测试。
实战案例
以下是一个演示如何使用自定义错误类型的实战案例:
package main
import (
"errors"
"fmt"
"os"
)
var ErrFileNotExist = errors.New("file not exist")
func OpenFile(filename string) (*os.File, error) {
f, err := os.Open(filename)
if err != nil {
return nil, ErrFileNotExist
}
return f, nil
}
func main() {
f, err := OpenFile("example.txt")
if err == ErrFileNotExist {
fmt.Println("File not exist")
} else if err != nil {
fmt.Println("Other error:", err)
} else {
fmt.Println(f)
}
}在该案例中,我们使用 OpenFile 函数打开一个文件。如果文件不存在,我们会返回 ErrFileNotExist 错误。在 main 函数中,我们处理该错误并打印相应的错误信息。










