인터페이스에 Nil 슬라이스 전달: 수수께끼 풀기
Go에서는 nil 슬라이스와 nil 인터페이스{} 값의 구별이 가능합니다. 예상치 못한 결과를 초래합니다. 다음 놀이터 발췌문을 고려해보세요.
<code class="go">package main import "fmt" func main() { var i []int = nil yes(i) // true no(i) // false } func yes(thing []int) { fmt.Println(thing == nil) } func no(thing interface{}) { fmt.Println(thing == nil) }</code>
이러한 함수는 왜 다른 출력을 생성합니까?
인터페이스 이해{}
인터페이스{} 변수 유형과 데이터라는 두 가지 필드가 있는 구조체와 유사합니다. 이 경우에는 {[]int (type), nil (data)}와 같습니다.
Nil Slice vs. Nil Interface
그렇습니다. nil 슬라이스가 직접 전달됩니다. 비교에서는 nil이 nil과 같은지 확인하여 true로 평가됩니다.
아니요, nil 슬라이스는 인터페이스{}에 래핑되어 {[]int(유형), nil(데이터)}가 됩니다. 이 인터페이스를 nil과 비교하면 유형이 nil인지 확인하지만 그렇지 않습니다. 따라서 출력은 false입니다.
차이가 발생하는 이유
이 동작은 인터페이스가 유형과 값을 모두 캡슐화한다는 사실에서 비롯됩니다. 인터페이스를 nil과 비교하면 nil 유형이 있는지 확인하지만 기본 데이터 값을 비교하는 것은 다릅니다. no의 경우에는 타입이 nil이 아니므로 비교 결과는 false를 반환합니다.
결론
역설적으로 보이는 동작은 nil 슬라이스 간의 미묘한 차이에 기인합니다. 인터페이스가 없습니다. Go에서 인터페이스를 사용할 때 혼란을 피하려면 이러한 차이점을 이해하는 것이 중요합니다.
위 내용은 nil 슬라이스를 인터페이스와 비교하면{} nil 슬라이스를 nil과 직접 비교하는 것과 다른 결과가 나오는 이유는 무엇인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!