C에서 기본 클래스의 생성자와 할당 연산자를 활용하는 방법
C에서 상속 클래스는 다음을 포함하여 기본 클래스의 동작을 상속할 수 있습니다. 생성자와 할당 연산자. 생성자 집합과 할당 연산자가 있는 기본 클래스 B를 생각해 보세요.
<code class="cpp">class B { public: B(); B(const string& s); B(const B& b) { *this = b; } B& operator=(const B& b); };</code>
이제 다음을 포함하여 동일한 생성자 집합을 상속하면서 foo() 함수를 재정의하는 파생 클래스 D를 생성하려고 합니다. 복사 생성자와 할당 연산자. 그러나 중복을 피하기 위해 B의 기존 생성자와 연산자를 사용하려고 합니다.
명시적 호출:
기본 클래스의 생성자와 할당 연산자를 명시적으로 호출할 수 있습니다. 파생 클래스의 생성자와 할당 연산자 내에서 각각. 이렇게 하면 기본 클래스의 멤버 변수가 적절하게 초기화됩니다.
<code class="cpp">class D : public B { public: D(const D& d) : B(d), additional_(d.additional_) {} D& operator=(const D& d) { B::operator=(d); additional_ = d.additional_; return *this; } private: int additional_; };</code>
암시적 호출:
흥미롭게도 복사 생성자를 명시적으로 정의하지 않더라도 파생 클래스의 할당 연산자를 사용하면 컴파일러는 기본 버전을 생성합니다. 이러한 기본 버전은 각각 기본 클래스의 복사 생성자와 할당 연산자를 암시적으로 호출합니다.
예를 들어 다음 기본 클래스의 경우:
<code class="cpp">class ImplicitBase { int value_; };</code>
다음 파생 클래스의 할당 연산자는 암시적으로 기본 클래스를 호출합니다. 클래스 할당 연산자:
<code class="cpp">class Derived : public ImplicitBase { const char* name_; public: Derived& operator=(const Derived& d) { ImplicitBase::operator=(d); // Implicit call to base class's assignment operator name_ = strdup(d.name_); return *this; } };</code>
위 내용은 C에서 기본 클래스의 생성자와 할당 연산자를 어떻게 활용합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!