>  기사  >  백엔드 개발  >  다형성 기본 클래스 포인터에서 파생 클래스 인스턴스를 생성하는 방법: 복제 메서드 및 CRTP 관용구 가이드

다형성 기본 클래스 포인터에서 파생 클래스 인스턴스를 생성하는 방법: 복제 메서드 및 CRTP 관용구 가이드

Susan Sarandon
Susan Sarandon원래의
2024-10-27 00:21:30219검색

How to Create Derived Class Instances from a Polymorphic Base Class Pointer:  A Guide to Clone Methods and the CRTP Idiom

다형성 기본 클래스에 대한 포인터에서 파생 클래스 인스턴스 생성

이 문제는 파생 클래스 인스턴스의 복사본을 생성하려고 할 때 발생합니다. 다형성 기본 클래스에 대한 포인터에서. 순진한 접근 방식에는 수많은 유형 검사와 동적 캐스트가 포함되며, 각 잠재적 파생 유형을 확인하고 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.