생성자에서 호출된 C 가상 함수가 예기치 않게 동작할 수 있는 이유
C에서 가상 함수는 동적 바인딩을 제공하여 파생 클래스가 기본 클래스에 정의된 함수입니다. 그러나 생성자에서 가상 함수를 호출하면 예상치 못한 결과가 발생할 수 있습니다.
다음 코드 조각을 고려하세요.
#include <iostream> 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; }
코드는 가상 함수를 사용하여 기본 클래스와 파생 클래스라는 두 클래스를 정의합니다. 값(). 기본 생성자는 객체 초기화 중에 value()를 호출합니다. 파생된 유형의 개체가 생성되므로 코드가 실행될 때 "1"이 인쇄될 것으로 예상할 수 있습니다. 그러나 대신 "0"이 출력됩니다.
이러한 동작이 발생하는 이유는 객체 구성 순서에 있습니다. 파생된 유형의 개체를 초기화할 때 기본 클래스 생성자가 먼저 호출됩니다. 이 시점에서 개체는 아직 완전히 초기화되지 않았으며 파생 클래스 관련 데이터 멤버가 초기화되지 않았을 수 있습니다. 결과적으로 기본 생성자에서 value()를 호출하면 0을 반환하는 함수의 기본 클래스 구현이 호출됩니다.
의도한 동작을 달성하려면 생성 후에서 value() 함수를 호출해야 합니다. 객체가 완전히 초기화되는 것이 보장되는 단계입니다. 이는 파생 클래스의 value() 함수를 재정의하고 생성 후 호출이 보장되는 별도의 메서드에서 호출하여 수행할 수 있습니다. 예:
struct derived : public base { virtual const int value() const { return 1; } int get_value() const { return value(); } };
이 경우 생성자에서 get_value() 메서드를 호출하여 "1"의 올바른 값을 얻을 수 있습니다.
위 내용은 생성자에서 호출된 C 가상 함수가 기본 클래스 값을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!