Go에서 메소드 오버로딩: 인수 유형 제한
Go에서는 이름과 인수 개수(인수 개수)가 동일한 메소드가 작동할 수 있습니다. 다른 유형에. 그러나 이러한 메서드의 수신자를 인수로 이동하려고 하면 컴파일 오류가 발생합니다.
다음 코드를 고려하세요.
type A struct { Name string } type B struct { Name string } func (a *A) Print() { fmt.Println(a.Name) } func (b *B) Print() { fmt.Println(b.Name) } func main() { a := &A{"A"} b := &B{"B"} a.Print() b.Print() }
이 코드는 "A"를 성공적으로 인쇄합니다. 콘솔에 "B"를 입력합니다. 그러나 메소드 시그니처를 다음과 같이 수정하면:
func Print(a *A) { fmt.Println(a.Name) } func Print(b *B) { fmt.Println(b.Name) } func main() { a := &A{"A"} b := &B{"B"} Print(a) Print(b) }
컴파일 오류가 발생합니다:
./test.go:22: Print redeclared in this block previous declaration at ./test.go:18 ./test.go:40: cannot use a (type *A) as type *B in function argument
제한 이유
Go는 인수 유형에 따른 사용자 정의 함수의 오버로드를 지원하지 않습니다. 이는 함수 이름과 인수 유형 모두를 기반으로 오버로드를 허용하는 C와 같은 일부 다른 언어와 대조됩니다.
Go에서 이름과 개수가 동일한 함수는 서명이 동일해야 합니다. 하나의 매개변수에 대해 함수를 "오버로드"하려면 메서드를 사용해야 합니다. 예를 들어, 각 구조체에 대해 Print 메소드를 생성할 수 있습니다.
func (a A) Print() { fmt.Println(a.Name) } func (b B) Print() { fmt.Println(b.Name) }
이 접근 방식을 사용하면 코드의 유형 안전성을 유지하면서 동일한 메소드 이름을 사용할 수 있습니다.
위 내용은 Go가 인수 유형에 따른 함수 오버로딩을 지원하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!