다형성 기본 클래스에 대한 포인터에서 파생 클래스 인스턴스 생성
이 문제는 파생 클래스 인스턴스의 복사본을 생성하려고 할 때 발생합니다. 다형성 기본 클래스에 대한 포인터에서. 순진한 접근 방식에는 수많은 유형 검사와 동적 캐스트가 포함되며, 각 잠재적 파생 유형을 확인하고 new 연산자를 사용합니다. 그러나 더 세련된 솔루션도 있습니다.
핵심은 가상 메소드인 Base* clone() const = 0;을 기본 클래스에 통합하는 것입니다. 그런 다음 각 파생 클래스는 이 메서드를 재정의하여 특정 복제본을 만들어야 합니다. 예를 들어:
<code class="cpp">class Base { virtual ~Base(); virtual Base* clone() const = 0; }; class Derived1 : public Base { virtual Base* clone() const override { return new Derived1(*this); } }; class Derived2 : public Base { virtual Base* clone() const override { return new Derived2(*this); } };</code>
기본 포인터에서 clone()을 호출하면 특정 파생 클래스의 새 인스턴스를 얻을 수 있습니다. 이 간소화된 접근 방식을 사용하면 유형 검사나 동적 캐스트가 필요하지 않아 코드 명확성과 효율성이 향상됩니다.
그러나 코드 중복을 피하려면 CRTP(Curiously Recurring Template Pattern) 관용구를 활용하는 것이 좋습니다. 템플릿 클래스는 다음과 같이 정의할 수 있습니다.
<code class="cpp">template <class Derived> class DerivationHelper : public Base { public: virtual Base* clone() const override { return new Derived(static_cast<const Derived&>(*this)); } }; class Derived1 : public DerivationHelper<Derived1> { ... }; class Derived2 : public DerivationHelper<Derived2> { ... };</code>
이 템플릿 클래스는 파생 클래스에서 상속될 때 clone() 메서드에 필요한 구현을 제공하므로 각 파생 클래스에서 별도의 재정의가 필요하지 않습니다. .
위 내용은 다형성 기본 클래스 포인터에서 파생 클래스 인스턴스를 생성하는 방법: 복제 메서드 및 CRTP 관용구 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!