모든 유형 및 Go에서 일반 목록 구현
Go 프로그래밍에서는 제네릭이 부족하여 데이터 구조 구현에 문제가 발생할 수 있습니다. . 두 가지 일반적인 문제를 해결해 보겠습니다.
1. 일반 목록 구현
Go는 일반 목록을 직접 지원하지 않지만 모든 값을 나타내는 인터페이스{} 유형을 제공합니다. 이 인터페이스를 사용하면 모든 유형의 값을 보유할 수 있는 "일반" 데이터 구조를 생성할 수 있습니다.
그러나 인터페이스{}를 사용하면 값에 액세스할 때 수동으로 값을 입력해야 하기 때문에 단점이 있습니다. 예를 들어, 다음 코드는 인터페이스 목록을 정의합니다.{}:
type AnyList []interface{}
목록에 정수를 추가하려면:
list := AnyList{1}
정수를 검색하려면 다음을 입력해야 합니다. 원래 유형으로 되돌리기:
value := list[0].(int)
2. 특정 유형의 필드로 컨테이너 만들기
Go에는 Haskell의 List a 또는 Scala의 val List[Animal { type 적절한Food = Grass} ]와 같은 대수 데이터 유형과 직접적으로 동등한 것이 없습니다. 그러나 인터페이스와 임베딩의 조합을 사용하면 유사한 결과를 얻을 수 있습니다.
예를 들어 동물에 대한 인터페이스를 정의할 수 있습니다.
type Animal interface { GetSuitableFood() string }
그런 다음 동물에 대한 구조체를 정의할 수 있습니다. 문자열 유형의 "SuitableFood" 필드가 있는 경우:
type GrassEatingAnimal struct { Animal SuitableFood string }
먹을 수 있는 동물 목록을 생성하려면 grass:
list := []*GrassEatingAnimal{}
목록에 동물을 추가하려면:
animal := &GrassEatingAnimal{SuitableFood: "Grass"} list = append(list, animal)
이 접근 방식은 언어에 비해 수동 작업이 더 많이 필요하지만 특정 유형의 필드가 포함된 컨테이너를 만드는 방법을 제공합니다. 제네릭으로.
위 내용은 제네릭 없이 Go에서 제네릭 목록과 유형별 컨테이너를 어떻게 구현할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!