템플릿 상속 및 비종속 이름 조회 이해
다음 코드 조각을 고려하세요.
<code class="cpp">// arrayListType.h template <class elemType> class arrayListType { protected: elemType *list; int length; }; // unorderedArrayListType.h template <class elemType> class unorderedArrayListType: public arrayListType<elemType> { }; // main1.cpp unorderedArrayListType<int> intList(25);</code>
이것을 컴파일합니다. 코드에서 오류가 발생합니다. "길이가 이 범위에서 선언되지 않았습니다." 이는 상위 클래스 arrayListType의 보호된 변수가 상속된 클래스 unorderedArrayListType에 표시되지 않음을 나타냅니다.
이는 개념 때문입니다. 컴파일러가 템플릿 내의 비종속 이름에 대한 참조를 확인하는 방법을 정의하는 비종속 이름 조회라고 합니다. 비종속적 이름은 멤버 변수나 멤버 함수 이름과 같이 템플릿 매개변수에 의존하지 않는 이름입니다.
이 경우 arrayListType 내의 보호된 변수는 비종속적 이름이며 명시적으로 지정되지 않습니다. unorderedArrayListType 클래스 정의에 정의되어 있습니다. 컴파일러는 이러한 이름이 상속된 클래스 내에 존재하는지 확인할 수 없으므로 오류를 보고합니다.
오류 수정
이 오류를 해결하는 두 가지 일반적인 접근 방식이 있습니다.
이것을 이용해서-> 접두사:
비종속 이름 앞에 this-> 상속된 멤버를 참조함을 명시적으로 나타냅니다.
<code class="cpp">class unorderedArrayListType: public arrayListType<elemType> { public: void insertAt(int location, const elemType& insertItem) { this->length++; this->list[location] = insertItem; } };</code>
선언 사용:
선언을 사용하면 상속된 클래스 내에서 비종속 이름을 명시적으로 선언합니다.
<code class="cpp">class unorderedArrayListType: public arrayListType<elemType> { public: using arrayListType<elemType>::list; using arrayListType<elemType>::length; void insertAt(int location, const elemType& insertItem) { length++; list[location] = insertItem; } };</code>
두 방법 모두 종속되지 않은 이름이 상속된 클래스에 속한다는 사실을 컴파일러에 효과적으로 전달하여 컴파일이 성공적으로 진행될 수 있도록 합니다.
위 내용은 템플릿 파생 클래스에서 내 기본 클래스의 보호된 멤버에 액세스할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!