C에서 재정의에도 불구하고 기본 클래스 가상 함수 호출
객체 지향 프로그래밍에서는 파생 클래스가 가상 함수를 재정의하는 것이 일반적입니다. 그들의 기본 클래스. 그러나 파생 클래스가 재정의된 함수에 액세스해야 하는 상황이 발생할 수 있습니다.
다음 C 코드를 고려하세요.
class Foo { public: int x; virtual void printStuff() { std::cout << x << std::endl; } }; class Bar : public Foo { public: int y; void printStuff() { // I would like to call Foo.printStuff() here... std::cout << y << std::endl; } };
위 예에서 Bar 클래스는 printStuff 함수를 재정의합니다. 하지만 기본 클래스 버전에 액세스해야 할 수도 있습니다.
Java의 super 대 C 구문
Java에서 super.funcname() 구문을 사용하면 파생 클래스가 기본 클래스 메서드를 호출할 수 있습니다. 그러나 C에는 다른 접근 방식이 필요합니다. 재정의된 기본 클래스 함수를 호출하려면 다음 구문을 사용합니다.
class Bar : public Foo { // ... void printStuff() override { // help the compiler to check Foo::printStuff(); // calls base class' function } };
이 구문에서:
C에서는 Java와 달리 다중 상속을 허용하므로 이러한 명시적인 명명이 필요합니다. 결과적으로 컴파일러는 재정의 시 어떤 기본 클래스 메서드를 호출해야 하는지 알아야 합니다.
사용 예
원본 코드로 돌아가면 다음 수정을 통해 Bar가 허용됩니다. :printStuff()는 자신의 데이터 멤버 y와 기본 클래스 데이터 멤버 x에 모두 액세스합니다.
void printStuff() override { Foo::printStuff(); std::cout << y << std::endl; }
이로 인해 개선되었습니다. printStuff 버전은 기본 클래스의 x 값과 파생 클래스의 y 값을 출력하여 원하는 기능을 제공합니다.
위 내용은 C의 파생 클래스에서 기본 클래스의 가상 함수를 어떻게 호출할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!