>백엔드 개발 >C++ >C의 기본 클래스 포인터에서 파생 클래스 인스턴스의 복사본을 만드는 방법은 무엇입니까?

C의 기본 클래스 포인터에서 파생 클래스 인스턴스의 복사본을 만드는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-26 04:55:31478검색

How to Create Copies of Derived Class Instances from Base Class Pointers in C  ?

다형성: 기본 클래스 포인터에서 파생 클래스 인스턴스의 복사본 만들기

객체 지향 프로그래밍에서는 필요한 시나리오를 접하는 것이 일반적입니다. 다형성 기본 클래스에 대한 포인터를 통해 파생 클래스 인스턴스에 액세스하는 동안 파생 클래스 인스턴스의 복사본을 만듭니다. 특히 외부 라이브러리나 복잡한 코드 구조의 사용을 피할 때 이 작업은 어려울 수 있습니다.

문제:

다음 클래스 계층 구조를 고려하세요.

<code class="cpp">class Base {
  virtual ~Base();
};
class Derived1 : public Base { ... };
class Derived2 : public Base { ... };</code>

목표는 base가 가리키는 인스턴스의 동적으로 생성된 복사본을 반환하는 CreateCopy(Base* base) 메서드를 만드는 것입니다. 런타임 오류를 방지하려면 임시 개체에 대한 참조를 반환하지 않는 것이 중요합니다.

순진한 접근 방식:

순진한 접근 방식에는 여러 유형 ID 또는 동적 캐스트를 사용하는 작업이 포함됩니다. 일련의 if 문을 사용하여 특정 파생 클래스 유형을 결정한 다음 new 연산자를 활용하여 복사본을 만듭니다. 그러나 이 방법은 번거롭고 오류가 발생하기 쉽습니다.

더 나은 접근 방식:

더 우아하고 다재다능한 솔루션은 기본 클래스에 가상 메서드를 도입하는 것입니다.

<code class="cpp">class Base {
  virtual ~Base();
  virtual Base* clone() const = 0;
};</code>

그런 다음 각 파생 클래스는 자체 clone() 메서드를 구현하여 인스턴스 복사본을 만듭니다.

CRTP(Curiously Recurring Template Pattern):

각 파생 클래스에서 clone() 구현이 중복되는 것을 방지하려면 템플릿 클래스를 통해 CRTP 관용어를 활용할 수 있습니다.

<code class="cpp">template <class Derived>
class DerivationHelper : public Base {
public:
  virtual Base* clone() const {
    return new Derived(static_cast<const Derived&>(*this)); // call the copy ctor.
  }
};</code>

이제 파생 클래스는 Base에서 직접 상속하는 대신 DerivationHelper에서 상속할 수 있습니다. :

<code class="cpp">class Derived1 : public DerivationHelper<Derived1> { ... };
class Derived2 : public DerivationHelper<Derived2> { ... };</code>

이 접근 방식을 사용하면 각 클래스에서 수동으로 구현할 필요 없이 파생된 모든 클래스가 clone() 메서드에 액세스할 수 있습니다.

위 내용은 C의 기본 클래스 포인터에서 파생 클래스 인스턴스의 복사본을 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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