"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > ## 템플릿 기본 클래스를 사용한 다중 상속으로 인해 멤버 함수 결정이 모호해지는 이유는 무엇입니까?

## 템플릿 기본 클래스를 사용한 다중 상속으로 인해 멤버 함수 결정이 모호해지는 이유는 무엇입니까?

2024-11-08에 게시됨
검색:955

## Why Does Multiple Inheritance with Template Base Classes Cause Ambiguity in Member Function Resolution?

다중 상속 명확성의 모호성

템플릿 기본 클래스를 사용하여 다중 상속을 처리할 때 모호한 멤버 함수 해결과 관련된 잠재적인 문제가 발생합니다. 다음 시나리오를 고려하십시오.

template 
class Base {
public:
  template 
  typename std::enable_if::value>::type foo() {
    std::cout 

여기서 foo() 함수는 템플릿 매개변수가 Types 팩의 유형 중 하나와 일치하는 경우에만 호출 가능합니다. 이제 파생 클래스가 겹치지 않는 유형 집합이 있는 여러 기본 클래스에서 상속되는 경우 컴파일러는 foo() 호출을 해결할 때 모호성을 경험할 수 있습니다.

struct Derived: public Base,
                public Base
{};

이 경우 Derived().foo() 호출은 이상적으로 Base에서 foo() 멤버 함수를 호출합니다. 그러나 GCC와 Clang 모두 모호성을 보고합니다.

컴파일러가 모호성을 해결할 수 없는 이유

컴파일 오류는 멤버 함수 조회에 대한 병합 규칙으로 인해 발생합니다. C 표준에 따르면 파생 클래스 자체에 멤버 함수가 선언되지 않은 경우 조회 프로세스는 기본 클래스를 차례로 검색합니다. 그러나 기본 클래스의 선언 세트가 다르면 병합이 모호해집니다.

주어진 시나리오에서 파생 클래스 Derived는 foo()를 명시적으로 선언하지 않으므로 컴파일러는 두 개의 기본 클래스. 기본 클래스에는 foo()에 대한 다양한 선언 세트가 포함되어 있으므로 병합으로 인해 모호성이 발생합니다.

솔루션

이 모호성을 해결하기 위한 한 가지 옵션은 using 선언을 사용하는 것입니다. 파생 클래스에서 원하는 멤버 함수를 명시적으로 가져옵니다. 그러나 이를 위해서는 사용자가 이러한 선언을 추가해야 하며 이는 큰 유형 목록의 경우 장황하고 비실용적일 수 있습니다.

struct Derived: public Base,
                public Base
{
    using Base::foo;
    using Base::foo;
};

또는 모든 기본 클래스에서 멤버 함수를 수집하고 병합하여 파생 클래스가 멤버 함수에 직접 액세스할 수 있도록 하는 도우미 클래스를 사용할 수 있습니다.

template 
struct BaseCollector : Bases...
{
  using Bases::foo...;
};

struct Derived : BaseCollector, Base>
{};

이 접근 방식을 사용하면 사용자는 모호성을 해결하기 위해 추가 선언을 추가할 필요가 없습니다. BaseCollector 클래스는 모든 기본 클래스의 선언 세트를 효과적으로 병합하여 모호함 없이 파생 클래스에서 foo() 함수를 사용할 수 있도록 합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3