제공된 코드 조각에서 B *b = new를 사용하여 클래스 B의 개체를 초기화하려고 하면 오류가 발생합니다. B(5); 기본 클래스 A에 생성자가 있음에도 불구하고. 이는 왜 상속된 생성자에 액세스할 수 없는지에 대한 질문을 제기합니다. case.
이 문제를 이해하는 열쇠는 C의 복잡한 생성자 상속 규칙에 있습니다. 명시적인 생성자 상속이 없으면 파생 클래스는 기본 클래스에서 생성자를 자동으로 상속하지 않습니다. 이는 C 03 표준의 경우였습니다. 생성자 상속을 달성하려면 파생 클래스는 수정된 다음 코드에서 볼 수 있듯이 using 키워드를 명시적으로 사용해야 합니다.
class A { public: explicit A(int x) {} }; class B: public A { using A::A; };
using A::A;가 추가되어 이제 클래스 B는 다음에서 생성자를 상속합니다. 클래스 A, 오류를 해결합니다. 이 상속은 기본 클래스의 모든 생성자에 적용되며 파생 클래스는 특정 생성자만 선택적으로 상속할 수 없다는 점에 유의하는 것이 중요합니다.
컴파일러가 C 11 표준을 지원하는 경우 생성자에 using 키워드를 활용할 수 있습니다. 계승. 그러나 C 03 표준에서는 생성자가 기본적으로 상속되지 않으며 기본 생성자를 호출하여 파생 클래스에서 수동으로 구현해야 했습니다.
템플릿 기반 클래스의 경우 using 키워드를 사용하여 다음을 수행할 수도 있습니다. 다음 예에 표시된 대로 생성자를 상속합니다.
template<class T> class my_vector : public vector<T> { public: using vector<T>::vector; ///Takes all vector's constructors /* */ };
위 내용은 C에서 파생 클래스가 생성자를 상속하지 않는 이유와 이를 어떻게 해결할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!