다중 상속이 포함된 오버로드된 함수의 모호성
객체 지향 프로그래밍에서 다중 상속을 사용하면 파생 클래스가 여러 기본 클래스에서 상속될 수 있습니다. 그러나 이로 인해 이름은 같지만 시그니처가 다른 여러 상속된 함수가 컴파일 중에 모호성을 만드는 상황이 발생할 수 있습니다.
다음 코드 조각을 고려하세요.
struct Base1{ void foo(int){ } }; struct Base2{ void foo(float){ } }; struct Derived : public Base1, public Base2{ }; int main(){ Derived d; d.foo(5); }
여기서 Derived 클래스는 서로 다른 매개변수 유형을 사용하여 Base1과 Base2 모두에서 foo() 함수를 상속합니다. d.foo(5)에 대한 호출이 기본 함수에서 수행되면 컴파일러는 호출할 함수를 결정할 수 없으며 "foo에 대한 모호한 호출" 오류가 발생합니다.
멤버 조회 규칙 방법 모호성 판단
이 모호함의 이유를 이해하려면 C 표준에 정의된 멤버 조회 규칙을 살펴봐야 합니다. 컴파일러는 함수 정의를 검색할 때 먼저 클래스와 해당 기본 클래스에 있는 함수의 모든 선언을 고려합니다. 그러나 이름은 같지만 클래스가 다른 여러 개의 선언이 있는 경우 숨겨진 선언이나 다른 하위 개체에서 오는 선언을 제거합니다.
여러 상속 함수의 경우 나머지 선언이 동일한 유형이 아니거나 다른 하위 개체의 비정적 멤버를 포함하는 경우 조회 결과가 모호해집니다. 이것이 주어진 코드 조각에서 우리가 직면한 상황입니다.
모호성 해결
이 상황에서 모호성을 해결하는 방법에는 여러 가지가 있습니다.
주어진 코드 조각에서 두 번째 예는 Derived 클래스 범위에 foo() 함수가 하나만 있으므로 작동합니다. . d.foo(5) 호출은 실제로 void foo(float) 함수를 호출합니다.
결론
서로 다른 시그니처를 가진 여러 상속된 함수는 컴파일 중에 모호성을 유발할 수 있습니다. 멤버 조회 규칙을 이해하고 정규화된 호출이나 선언과 같은 기술을 사용하면 이러한 모호성을 해결하고 적절한 함수 호출을 보장하는 데 도움이 될 수 있습니다.
위 내용은 C에서 다중 상속이 있는 오버로드된 함수의 모호성을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!