보호된 데이터 멤버가 있는 클래스를 상속할 때 자식 클래스의 초기화 목록을 사용하여 초기화하는 것이 바람직할 수 있습니다. 클래스의 생성자. 그러나 이 접근 방식은 종종 컴파일 오류로 이어집니다.
이 예에서:
<code class="cpp">class Parent { protected: std::string something; }; class Child : public Parent { private: Child() : something("Hello, World!") {} };</code>
하위 클래스 Child에 뭔가 이름이 지정된 멤버가 없기 때문에 이 코드를 컴파일하면 오류가 발생합니다. .
이 문제를 해결하려면 상위 클래스 Parent가 보호된 멤버를 초기화하는 생성자를 정의해야 합니다. 이 생성자는 보호됨으로 선언되어 파생 클래스에서 액세스할 수 있습니다.
아래 수정된 코드는 성공적으로 컴파일됩니다.
<code class="cpp">class Parent { protected: std::string something; Parent(const std::string& something) : something(something) {} }; class Child : public Parent { private: Child() : Parent("Hello, World!") {} };</code>
이 수정된 코드에서 상위 클래스의 보호된 생성자는 다음을 전달합니다. Something 멤버에 대한 초기화 인수를 사용하면 자식 클래스가 자체 초기화 중에 부모의 보호된 멤버를 초기화할 수 있습니다.
이 구문을 따르면 자식 클래스의 초기화 목록을 사용하여 보호된 부모 멤버를 초기화하는 것이 가능해집니다. 상속 계층 전체에서 객체 초기화에 대한 제어 및 유연성이 향상되었습니다.
위 내용은 하위 클래스가 초기화 목록을 통해 보호된 상위 멤버를 초기화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!