Go에는 Java와 같은 객체 지향 언어에서 볼 수 있는 메서드 재정의와 직접적으로 동일한 것이 없습니다. 그러나 유사한 기능을 달성하기 위한 대체 접근 방식이 있습니다.
문자열 "base"를 반환하는 Get() 메서드를 사용하여 기본 유형 Base가 있는 시나리오를 고려해 보세요. Base에서 상속하지만 "Sub"를 반환하는 Get()의 다른 구현을 갖는 새로운 유형 Sub를 정의하려고 합니다.
다음과 같은 구성 사용의 초기 시도:
type Sub struct { Base } func(sub *Sub) Get() string { return "Sub" }
Sub의 Get() 메서드는 Base의 Get() 메서드를 재정의할 수 없기 때문에 작동하지 않습니다. 이는 수신자 유형(이 경우 *Base)에 따라 호출할 메소드가 결정되는 Go의 메소드 수신자 의미론 때문입니다.
한 가지 대안 접근 방식은 인터페이스를 사용하는 것입니다. 인터페이스는 Java의 추상 클래스와 유사하게 유형이 구현해야 하는 메소드 계약을 정의합니다. 이 경우 단일 Get() 메서드를 사용하여 Getter 인터페이스를 정의할 수 있습니다.
type Getter interface { Get() string }
그런 다음 Base를 수정하여 Getter 인터페이스를 구현할 수 있습니다.
type Base struct { } func (base *Base) Get() string { return "base" }
이제 Sub를 Base 인스턴스를 포함하고 Getter도 구현하는 구조체로 정의할 수 있습니다.
type Sub struct { Base } func (sub *Sub) Get() string { return "Sub" }
그런 다음 다음을 사용할 수 있습니다. 호출할 Get()의 구현을 동적으로 결정하는 GetName() 메서드:
func (base *Base) GetName(getter Getter) string { if g, ok := getter.(Getter); ok { return g.Get() } else { return base.Get() } }
주 함수에서는 Sub 인스턴스를 생성하고 이를 Getter로 캐스팅한 다음 GetName( ):
userType := Sub{} fmt.Println(userType.GetName()) // prints "Sub"
또 다른 대안은 메소드 임베딩을 사용하는 것입니다. 이를 통해 해당 메소드를 구현하는 유형을 삽입하여 구조체에 메소드를 추가할 수 있습니다. 이 경우 Base를 포함하고 새로운 Get() 메소드를 구현하는 새로운 유형 SubGetter를 정의할 수 있습니다.
type SubGetter struct { Base } func (sub *SubGetter) Get() string { return "Sub" }
그런 다음 SubGetter를 Base의 메소드로 사용할 수 있습니다:
type Base struct { SubGetter }
이를 사용하면 SubGetter의 Get() 메서드를 마치 Base:
base := Base{} fmt.Println(base.Get()) // prints "Sub"의 메서드인 것처럼 호출할 수 있습니다.
위 내용은 Go에서 메소드 재정의 기능을 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!