Go의 재귀 오류 래핑
Go의 오류 처리 메커니즘은 오류 검사를 위해 Is() 및 As()와 같은 메서드를 제공합니다. 그러나 이러한 방법은 재귀적 오류 래핑을 지원한다고 가정되는 경우가 많습니다. 이는 전적으로 사실이 아닙니다.
%w 동사와 함께 fmt.Errorf를 사용하면 얕은 오류 래핑만 허용됩니다. 진정한 재귀를 달성하려면 사용자 정의 오류 유형이 필요합니다.
일반적으로 사용자 정의 오류 유형에는 래핑된 오류에 대한 포인터와 래핑 해제 방법이 포함됩니다. 그러나 단순히 이러한 방식으로 오류를 래핑하면 문제가 발생합니다. 여러 개의 래핑된 오류가 동일한 포인터를 공유하는 경우 Go 오류는 주소별로 비교되므로 오류 비교가 실패합니다.
해결책은 사용자 정의 오류 유형 내에서 Is() 및 As() 메서드를 구현하는 것입니다. 이러한 방법은 사용자 정의 유형 자체가 아닌 포함된 오류를 비교해야 하므로 주소 기반 문제 없이 전체 재귀 오류 래핑이 가능합니다.
예를 들어 다음은 재귀 래핑을 지원하는 오류 유형의 단순화된 버전입니다.
type errorChain struct { err error next *errorChain } func (c errorChain) Is(err error) bool { return errors.Is(c.err, err) } func (c errorChain) As(target any) bool { return errors.As(c.err, target) } func (c errorChain) Unwrap() error { return c.next }
그런 다음 이 오류 유형을 사용하여 원하는 대로 오류를 래핑할 수 있으므로 Is() 및 As()를 사용하여 전체 오류 검사가 가능합니다.
위 내용은 Go의 `errors.Is` 및 `errors.As`는 재귀 오류 래핑을 지원합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!