Go에서 임베디드 구조체는 기본 구조체의 필드와 메서드를 상속합니다. 그러나 기본 구조체와 포함된 구조체가 모두 동일한 이름을 가진 메서드를 구현하는 경우 충돌이 발생할 수 있습니다. 이 문서에서는 기본 구조체에 영향을 주지 않고 포함된 구조체의 메서드를 재정의하는 솔루션을 살펴봅니다.
다음 코드를 고려하세요.
<code class="go">package main import "fmt" type Base struct { val int } func (b *Base) Set(i int) { b.val = i } type Sub struct { Base changed bool } func (b *Sub) Set(i int) { b.val = i b.changed = true } func main() { s := &Sub{} s.Base.Set(1) var b *Base = &s.Base // Both print the same value fmt.Printf("%+v\n", b) fmt.Printf("%+v\n", s) }</code>
여기서 Sub 유형은 Base 유형을 포함합니다. Sub와 Base 모두 Set이라는 메서드가 있으며, s.Base.Set()을 호출하면 Sub.Set() 메서드를 우회하고 Base.Set() 메서드를 직접 호출하게 됩니다.
포함된 구조체의 메서드를 재정의하는 경우 대신 Sub.Set() 메서드를 호출할 수 있습니다. Go에서 유형이 포함된 유형과 동일한 이름의 메서드를 구현하면 포함된 메서드가 숨겨집니다.
다음은 코드의 업데이트된 버전입니다.
<code class="go">func (b *Sub) Set(i int) { b.Base.Set(i) // Call the Base.Set() method b.changed = true } func main() { s := &Sub{} s.Set(1) var b *Base = &s.Base // Note: b.val is now 1 // s.changed is now true fmt.Printf("%+v\n", b) fmt.Printf("%+v\n", s) }</code>
이 예에서는 , s.Set(1)을 호출하면 Sub.Set() 메서드가 호출되고 Base.Set() 메서드가 호출됩니다. 그러면 Sub에 포함된 Base 구조체의 val 필드가 업데이트됩니다. 변경된 필드도 true로 설정되어 값이 수정되었음을 나타냅니다.
이 솔루션을 사용하면 기본 구조체에 영향을 주지 않고 포함된 구조체의 메서드를 재정의할 수 있습니다. 코드 재사용성과 유연성을 달성하기 위해 Go에서 사용되는 일반적인 기술입니다.
위 내용은 기본 구조체에 영향을 주지 않고 Go에서 임베디드 구조체 메서드를 재정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!