파생 클래스에 대한 템플릿 형식 정의
C에서 템플릿을 사용하면 일반 클래스와 데이터 구조를 정의할 수 있습니다. 그러나 기본 클래스에서 파생 클래스로 typedef를 전파하려면 특정 처리가 필요합니다.
다음 코드를 고려하세요.
template<typename T> class A { public: typedef std::vector<T> Vec_t; }; template<typename T> class B : public A<T> { private: Vec_t v; // Error: Vec_t is not recognized };
이 예에서 클래스 A는 T 유형의 벡터에 대한 typedef를 정의합니다. , 파생 클래스 B에서 이 typedef를 사용하려고 하면 B의 범위 내에서 Vec_t가 인식되지 않기 때문에 오류가 발생합니다.
이유 이 문제는 템플릿의 기본 클래스 범위에 대한 C 표준의 처리에서 비롯됩니다. 표준의 섹션 14.6.2/3에 따르면:
"클래스 템플릿 또는 클래스 템플릿의 멤버 정의에서 클래스 템플릿의 기본 클래스가 템플릿 매개변수에 따라 달라지는 경우 정규화되지 않은 이름 조회 중에는 기본 클래스 범위가 검사되지 않습니다..."
이는 정규화되지 않은 이름을 사용할 때 기본 클래스에 정의된 형식 정의가 파생 클래스의 범위에서 자동으로 사용 가능하지 않음을 의미합니다. 이 문제를 해결하려면 typedef가 정규화되어야 합니다.
typename A<T>::Vec_t v;
typename 키워드와 typedef의 정규화된 이름을 사용하여 기본 클래스의 typedef를 사용하겠다고 명시적으로 지정합니다. . 이는 예상대로 작동하며 파생 클래스 내의 벡터 typedef에 액세스할 수 있게 해줍니다.
위 내용은 C의 파생 클래스 템플릿에 있는 기본 클래스 Typedef에 어떻게 액세스할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!