함수 그림자 좌절: 다른 시그니처로 누락된 함수 찾기
객체 지향 프로그래밍에서는 기본 클래스와 파생 클래스 사이에 이름 지정 충돌이 발생할 수 있습니다. 이름은 같지만 시그니처가 다른 함수가 존재할 때. 이로 인해 코드 실행 중에 혼란과 예상치 못한 동작이 발생할 수 있습니다. 이러한 시나리오는 다음 코드에서 발생했습니다.
class A { public: void foo(string s); }; class B : public A { public: int foo(int i); }; class C : public B { public: void bar() { string s; foo(s); } };
이 코드를 컴파일하려고 하면 foo를 호출할 때 C::foo(std::string&) 함수를 찾을 수 없어 오류가 발생합니다. (s) bar 메소드 내. 기본 클래스 A에 foo(string s)가 있음에도 불구하고 클래스 B에 상속된 foo(int i)는 기본 클래스 함수를 숨깁니다.
이 문제를 해결하고 원하는 함수에 액세스할 수 있도록 하려면 함수 기본 클래스의 클래스는 파생 클래스의 범위에서 명시적으로 다시 선언되어야 합니다. 이렇게 하면 파생 클래스와 그 하위 클래스 내에서 두 함수가 모두 표시됩니다.
class A { public: void foo(string s); }; class B : public A { public: int foo(int i); using A::foo; }; class C : public B { public: void bar() { string s; foo(s); } };
클래스 범위의 이름 조회는 현재 클래스 내 선언의 우선 순위를 지정하고 기본 클래스 sub에서 숨겨진 선언을 제거한다는 점에 유의하는 것이 중요합니다. -사물. 따라서 파생 클래스에 이름은 같지만 시그니처가 다른 함수를 도입하면 기본 클래스 함수가 모호해 설명된 오류가 발생할 수 있습니다.
위 내용은 C 상속의 함수 섀도잉 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!