在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語言中優雅地處理錯誤。