> 백엔드 개발 > Golang > Go에서 별도 패키지의 동일한 메서드 시그니처를 사용하여 인터페이스를 구현하는 방법은 무엇입니까?

Go에서 별도 패키지의 동일한 메서드 시그니처를 사용하여 인터페이스를 구현하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-03 19:57:30
원래의
660명이 탐색했습니다.

How to Implement Interfaces with Identical Method Signatures from Separate Packages in Go?

별도의 패키지에서 동일한 메서드 시그니처를 사용하여 인터페이스 구현

Go에서는 동일한 메서드 시그니처를 사용하여 두 개의 서로 다른 인터페이스를 구현하는 것이 불가능합니다. 다른 패키지. 일반적으로 각 인터페이스 유형은 특정 구현을 기대하여 유형 안전성을 보장합니다.

그러나 객체가 동일한 이름의 메서드로 여러 인터페이스를 충족해야 하는 경우 모든 인터페이스에 대해 일관된 논리를 구현하는 것이 어려울 수 있습니다.

사례 예:

동일한 메서드 시그니처를 가진 인터페이스 Doer가 포함된 두 개의 패키지 A와 B를 고려합니다.

package A
type Doer interface {
    Do() string
}
로그인 후 복사
package B
type Doer interface {
    Do() string
}
로그인 후 복사

문제 :

메인 패키지에서 단일 객체 C는 A.Doer와 B.Doer를 모두 구현하도록 설계되었습니다.

package main

func (c C) Do() string {
    return "C now implements both A and B"
}
로그인 후 복사

그러나 이 구현은 다음 경우에 버그를 발생시킵니다. C에서 구현된 Do 메소드는 A.Doer 전용이므로 B.FuncB(c)를 호출합니다.

해결책:

Go의 임베딩 기능을 사용하여 별도의 래퍼 유형 생성 가능:

  • DoerA: C를 포함하고 A.Do()를 구현합니다.
  • DoerB: C를 포함하고 B를 구현합니다. .Do().

적절한 래퍼 유형을 A.FuncA 및 B.FuncB에 인수로 전달하면 각 인터페이스에 대해 원하는 로직을 유지할 수 있습니다.

추가 참고 사항:

  • 어떤 경우에는 잠재적인 유형 충돌을 일으키지 않고 특정 인터페이스 요구 사항을 충족하기 위해 전용 구현 유형을 사용해야 할 수도 있습니다.
  • 복잡한 상속을 처리하는 경우 메서드 시그니처가 겹치는 여러 인터페이스가 포함된 시나리오에서는 논리를 신중하게 고려하고 통합 전반에 걸쳐 일관성을 보장하는 것이 중요합니다.

위 내용은 Go에서 별도 패키지의 동일한 메서드 시그니처를 사용하여 인터페이스를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿