생성자에서 가상 함수를 호출할 수 없는 이유
C에서 가상 함수는 파생 개체를 활성화하여 다형성에서 중요한 역할을 합니다. 기본 클래스에서 상속된 메서드를 재정의하는 클래스입니다. 그러나 클래스 생성자 내에서 가상 함수를 호출하려고 하면 일반적인 오해가 발생합니다.
다음 예제 코드를 고려하세요.
struct base { virtual const int value() const { return 0; } base() { std::cout << value() << std::endl; } virtual ~base() {} }; struct derived : public base { virtual const int value() const { return 1; } }; int main(void) { derived example; }
이 코드가 실행되면 대신 "0"이 출력됩니다. 예상되는 "1". 왜?
그 이유는 생성자 실행 순서에 있습니다. 파생 클래스 객체가 생성되면 기본 클래스 생성자가 먼저 호출됩니다. 이 시점에서는 파생 클래스 객체가 아직 완전히 구성되지 않았으며 해당 가상 메서드를 안정적으로 호출할 수 없습니다.
기본 클래스 생성자가 value()를 호출하면 가상 함수의 기본 클래스 구현에 액세스합니다. 파생 클래스는 아직 파생 개체로 "성숙"되지 않았습니다. 가상 함수가 올바르게 호출되도록 하려면 완전히 구성된 객체 내에서 액세스해야 합니다.
따라서 코드를 수정하고 "1"을 출력하려면 기본 클래스 생성자의 value() 메서드 호출이 다음과 같아야 합니다. 개체가 완전히 구성될 때까지 제거하거나 연기합니다.
위 내용은 생성자에서 호출된 가상 함수가 기본 클래스 구현을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!