在Go语言中,优雅地处理错误通常遵循以下几个原则:
func Divide(a, b int) (int, error) {
if b == 0 {
return 0, errors.New("division by zero")
}
return a / b, nil
}
defer
和recover
处理panic:在可能出现panic的地方使用defer
和recover
来捕获panic并优雅地处理错误。func SafeFunction() (result string, err error) {
defer func() {
if r := recover(); r != nil {
err = fmt.Errorf("panic occurred: %v", r)
}
}()
// 可能引发panic的操作
return "success", nil
}
type CustomError struct {
Code int
Message string
}
func (e *CustomError) Error() string {
return fmt.Sprintf("code: %d, message: %s", e.Code, e.Message)
}
func Divide(a, b int) (int, error) {
if b == 0 {
return 0, &CustomError{Code: 400, Message: "division by zero"}
}
return a / b, nil
}
errors
和fmt
包处理错误:利用errors
包创建错误,使用fmt
包格式化错误信息。import (
"errors"
"fmt"
)
func Divide(a, b int) (int, error) {
if b == 0 {
return 0, errors.New("division by zero")
}
return a / b, nil
}
log
包记录错误日志:在处理错误时,使用log
包记录错误日志,以便于排查问题。import (
"errors"
"log"
)
func Divide(a, b int) (int, error) {
if b == 0 {
log.Printf("error: division by zero")
return 0, errors.New("division by zero")
}
return a / b, nil
}
context
包传递错误上下文:在处理跨多个goroutine的错误时,使用context
包传递错误上下文信息。import (
"context"
"errors"
)
func Divide(ctx context.Context, a, b int) (int, error) {
if b == 0 {
return 0, context.NewCanceledError("division by zero")
}
return a / b, nil
}
通过遵循以上原则,你可以在Go语言中优雅地处理错误。