>  기사  >  백엔드 개발  >  Go에서 `nil` 인터페이스 값이 `error(nil)`와 같지 않은 이유는 무엇입니까?

Go에서 `nil` 인터페이스 값이 `error(nil)`와 같지 않은 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-30 18:45:30683검색

Why Does `nil` Interface Value Not Equal `error(nil)` in Go?

Nil 인터페이스 인스턴스 비교

아래 코드를 고려하세요.

<code class="go">type Goof struct {}

func (goof *Goof) Error() string {
    return fmt.Sprintf("I'm a goof")
}

func TestError(err error) {
    if err == nil {
        fmt.Println("Error is nil")
    } else {
        fmt.Println("Error is not nil")
    }
}

func main() {
    var g *Goof // nil
    TestError(g) // Displays "Error is not nil"
}</code>

놀랍게도 이 코드의 결과는 " nil 조건을 테스트하려는 의도에도 불구하고 오류는 nil이 아닙니다.

이 동작을 이해하는 열쇠는 Go가 인터페이스를 구현하는 방법에 있습니다. 내부적으로 인터페이스 값은 유형과 값으로 구성됩니다. 값은 nil일 수 있지만 유형은 nil이 될 수 없습니다. 주어진 예에서 (*Goof)(nil)은 "*Goof" 유형과 nil 값을 갖는 인터페이스 값입니다.

그러나 오류 인터페이스 유형은 "*Goof" 유형과 다릅니다. 따라서 (*Goof)(nil) 및 error(nil)는 둘 다 nil 값을 포함하더라도 동일하지 않습니다. 이는 다음 코드에서 분명하게 드러납니다.

<code class="go">var g *Goof // nil
var e error = g

if e == nil {
    fmt.Println("Error is nil")
} else {
    fmt.Println("Error is not nil")
}
// Output: Error is not nil</code>

이 문제를 해결하려면 여러 가지 접근 방식이 있습니다.

  1. var g *Goof 대신 var err error를 err's 0으로 선언합니다. 값은 편의상 오류(nil)입니다.
  2. 함수가 오류를 반환하는 경우 return nil을 사용하면 원하는 nil 인터페이스 값이 반환됩니다.

위 내용은 Go에서 `nil` 인터페이스 값이 `error(nil)`와 같지 않은 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.