JSON 역마샬링: 포인터 대 참조
json.Unmarshal 함수를 사용하면 JSON 데이터를 Go 구조체로 변환할 수 있습니다. 문서에서는 포인터가 nil인 경우 새 값을 할당할 수 있다고 제안하지만 그렇지 않습니다.
다음 예를 고려하세요.
var animals Animal err := json.Unmarshal(jsonBlob, &animals)
이것은 예상대로 작동합니다. nil이 아닌 포인터. 그러나 동물을 초기화되지 않은 포인터로 변경하면:
var animals *Animal err := json.Unmarshal(jsonBlob, animals)
이것은 모호한 오류 메시지와 함께 실패합니다:
json: Unmarshal(nil *main.Animal)
이 오류는 InvalidUnmarshalError에서 발생합니다. 인수는 Unmarshal에 전달됩니다. 문서에는 포인터가 nil이 아니어야 한다는 점을 명시적으로 명시하지 않아 혼란을 초래할 수 있습니다.
Unmarshal이 nil 포인터에 대해 새 값을 할당할 수 있음을 암시하는 문서의 상충되는 인용문은 다음을 참조하고 있을 수 있습니다. 포인터가 nil일 때 새 값을 생성하기 위해 Unmarshal에서 내부적으로 사용되는 Reflect.New 함수의 동작에 적용됩니다. 그러나 Reflect.New는 구조체 및 슬라이스와 같은 특정 유형에만 작동합니다. *int 또는 *string과 같은 기본 유형에 대한 포인터에는 작동하지 않습니다.
요약하면 json.Unmarshal에는 두 번째 인수로 nil이 아닌 포인터가 필요합니다. 기본 유형의 nil 포인터에는 새 값을 할당할 수 없습니다. 따라서 JSON 데이터를 역마샬링하기 전에 포인터가 nil이 아닌지 확인하는 것이 중요합니다.
위 내용은 기본 유형에 대한 Nil 포인터로 `json.Unmarshal`이 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!