가상 함수 설명: 가상 함수의 정의 및 순수 가상 함수와의 차이점
객체 지향 프로그래밍에서 가상 함수의 개념 런타임 다형성에 필수적입니다. 가상 함수는 클래스 계층 구조의 다양한 수준에서 다양한 구현을 제공하기 위해 파생 클래스에서 재정의될 수 있는 함수입니다.
가상 함수와 비가상 함수의 주요 차이점은 가장 많이 파생된 버전이라는 점입니다. 가상 함수가 재정의될 때 클래스 계층의 모든 수준에서 사용됩니다. 이와 대조적으로 가상이 아닌 함수의 기능은 파생 클래스에서 재정의되더라도 기본 클래스에서 변경되지 않습니다.
다음은 가상 함수의 동작을 보여주는 예입니다.
struct Base { virtual ~Base() = default; virtual void foo() { std::cout << "Base::Foo" << std::endl; } }; struct Derived final: Base { void foo() override { std::cout << "Derived::Foo" << std::endl; } };
이 코드를 실행하면 다음과 같은 출력이 생성됩니다.
Base::Foo Derived::Foo Derived::Foo
보시다시피 foo() 함수가 호출되면 Derived 클래스의 인스턴스에서는 기본 클래스 포인터(Base* 파생_as_base)를 통해 인스턴스에 액세스하는 경우에도 Derived::foo() 구현이 사용됩니다.
순수 가상 함수: 특수 사례
순수 가상 함수는 파생 클래스에서 구현해야 하는 가상 함수입니다. 기본 클래스에 정의되어 있지 않으며 클래스를 구체적으로 만들기 위해 파생 클래스에서 재정의해야 합니다. 하나 이상의 순수 가상 함수가 있는 클래스는 추상으로 간주되며 직접 인스턴스화할 수 없습니다.
다음은 순수 가상 함수의 예입니다.
struct Base { virtual ~Base() = default; virtual void foo() = 0; }; struct Derived final: Base { void foo() override { std::cout << "Derived::Foo" << std::endl; } };
이 경우 Base 클래스는 다음과 같습니다. 순수 가상 함수 foo()를 포함하고 있기 때문에 abstract입니다. 이 클래스를 사용하려면 파생 클래스가 foo() 함수를 구현하여 파생 클래스를 인스턴스화할 수 있는 구체적인 클래스로 만들어야 합니다.
요약하자면, 가상 함수를 사용하면 다양한 수준에서 기본 클래스 기능을 재정의할 수 있습니다. 반면 순수 가상 함수는 클래스를 구체적으로 만들기 위해 특정 기능을 구현하기 위해 파생 클래스가 필요합니다. 객체 지향 프로그래밍에서 확장 가능하고 다형성 코드를 작성하려면 이러한 개념을 이해하는 것이 중요합니다.
위 내용은 가상 및 순수 가상 기능: 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!