객체 지향 프로그래밍에서 파생 클래스는 상속할 수 있습니다. 기본 클래스의 멤버입니다. 그러나 이름은 같지만 시그니처가 다른 함수가 기본 클래스와 파생 클래스 모두에 존재하는 경우 문제가 발생할 수 있습니다. 이로 인해 "파생 클래스에서 이름은 같지만 서명이 다른 함수를 찾을 수 없습니다."와 같은 오류가 발생할 수 있습니다.
이 문제를 설명하려면 다음 코드 조각을 고려하세요.
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); // Error: no matching function } };
컴파일할 때 이 코드에서 컴파일러는 클래스 C의 bar() 함수 내의 foo(s) 호출에서 오류를 발견했습니다. 기본 클래스 A에 foo(string s) 함수가 있음에도 불구하고 함수 숨기기라는 현상으로 인해 컴파일러가 이를 인식하지 못합니다.
이 시나리오에서는 클래스 B에 정의된 foo(int i) 함수가 상속된 foo(string s) 함수를 숨깁니다. 클래스 A에서. 이는 클래스 계층 구조의 이름 조회가 일치하는 이름의 첫 번째 선언에서 중지되기 때문입니다. 따라서 조회 프로세스가 클래스 B에 도달하면 foo(int i) 함수를 찾고 기본 클래스에서 재정의된 foo(string s) 함수를 무시합니다.
이 문제를 해결하려면 파생 클래스의 범위에 있는 기본 클래스 함수입니다. using 키워드를 사용하여 기본 클래스 함수를 상속하면 파생 클래스와 해당 하위 클래스 내에서 두 함수가 모두 표시됩니다.
class A { public: void foo(string s) {} }; class B : public A { public: int foo(int i) {} using A::foo; // Redeclare base class foo function }; class C : public B { public: void bar() { string s; foo(s); // Now finds the base class foo(string s) } };
이 줄을 클래스 B에 통합하면 이름 조회에서 foo( int i) 및 foo(string s) 함수를 사용하여 함수 숨김 문제를 해결했습니다.
위 내용은 C 상속에서 '파생 클래스에서 이름은 같지만 서명이 다른 함수를 찾을 수 없습니다'가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!