Go 中的错误包装和展开

在 go 中,错误包装和展开用于处理和传递错误信息,增强了错误的理解和调试。错误包装允许添加上下文,而错误展开则允许提取原始错误。实战案例中,http 客户端函数嵌入了错误信息,使用错误展开可以获取原始错误,方便问题排查。

Go 中的错误包装和展开

Go 中的错误包装和展开

在 Go 中,错误处理至关重要,特别是当处理外部服务或操作时。错误包装和展开提供了灵活的方法来处理和传递错误信息。让我们深入了解这两个概念及其实际应用。

错误包装

错误包装允许您创建新的错误,其中封装了另一个错误。这对于在不丢失原始错误信息的情况下添加额外的上下文很有用。要进行错误包装,请使用 errors.Wrap() 函数:

import "errors"

func ExampleErrorWrap() error {
    originalErr := errors.New("original error")
    wrappedErr := errors.Wrap(originalErr, "wrapped error")
    return wrappedErr
}

现在,wrappedErr 携带了原始错误信息和附加上下文。

错误展开

相反,错误展开允许从包装错误中提取原始错误。errors.Unwrap() 函数可用于此目的:

import "errors"

func ExampleErrorUnwrap() error {
    wrappedErr := errors.New("wrapped error")
    originalErr := errors.Unwrap(wrappedErr)
    return originalErr
}

现在,originalErr 将包含原始错误信息。

实战案例:HTTP 客户端

考虑下面处理 HTTP GET 请求的函数:

import (
    "context"
    "net/http"
)

func GetProduct(ctx context.Context, url string) (*http.Response, error) {
    req, err := http.NewRequest(http.MethodGet, url, nil)
    if err != nil {
        return nil, errors.Wrap(err, "failed to create HTTP request")
    }

    resp, err := http.DefaultClient.Do(req)
    if err != nil {
        return nil, errors.Wrap(err, "failed to execute HTTP request")
    }

    return resp, nil
}

在这里,我们嵌入了错误信息,即 "failed to create HTTP request" 和 "failed to execute HTTP request"。这增强了对错误的理解:

resp, err := GetProduct(ctx, url)
if err != nil {
    unwrappedErr := errors.Unwrap(err)
    fmt.Println(unwrappedErr) // "failed to create HTTP request" 或 "failed to execute HTTP request"
}

这种错误包装和展开的组合既提供了上下文信息又保留了原始错误,从而简化了调试和错误处理。

以上就是Go 中的错误包装和展开的详细内容,更多请关注其它相关文章!