> 백엔드 개발 > C++ > 파생 클래스에서 기본 템플릿 클래스의 정적 멤버에 액세스할 수 없는 이유는 무엇입니까?

파생 클래스에서 기본 템플릿 클래스의 정적 멤버에 액세스할 수 없는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-18 00:34:02
원래의
650명이 탐색했습니다.

Why are Static Members of Base Template Classes Inaccessible in Derived Classes?

파생 템플릿 클래스의 기본 템플릿 클래스 식별자 가시성

다음 코드 조각을 고려하세요.

template<typename T>
class Base
{
public:
    static const bool ZEROFILL = true;
    static const bool NO_ZEROFILL = false;
};

template<typename T>
class Derived : public Base<T>
{
public:
    Derived(bool initZero = NO_ZEROFILL);    // NO_ZEROFILL is not visible
    ~Derived();
};
로그인 후 복사

GCC g 3.4.4(cygwin)로 컴파일하면 이 코드 컴파일이 실패합니다. NO_ZEROFILLDerived 템플릿 클래스에 표시되지 않습니다. 이 동작은 C의 2단계 조회로 인해 발생할 수 있습니다.

C의 2단계 조회

컴파일러가 템플릿 선언을 발견하면 예비 단계만 수행합니다. 해당 템플릿 내에서 사용되는 식별자를 검색합니다. T의 실제 유형은 이 단계에서 결정되지 않으므로 컴파일러는 Base::NO_ZEROFILL과 같이 이 유형에 의존하는 식별자를 확인할 수 없습니다.

2단계 조회 프로세스:

  1. 예비 조회: 식별자는 현재 범위 내에서 그리고 이전에 선언된 네임스페이스에서 검색됩니다.
  2. 템플릿 인스턴스화: 템플릿이 특정 유형 매개변수로 인스턴스화되면 두 번째 조회가 수행되어 다음을 수행합니다. 인스턴스화된 멤버와 식별자를 찾습니다.

이 경우 NO_ZEROFILL은 알 수 없는 유형 T에 따라 달라지므로 예비 조회 중에 표시되지 않습니다. 결과적으로 파생 클래스에서 Base::NO_ZEROFILL 또는 this->NO_ZEROFILL을 명시적으로 지정하여 해당 유형이 다음과 같은 기본 클래스의 멤버임을 나타내야 합니다. 템플릿 인스턴스화 시간에 결정됩니다.

위 내용은 파생 클래스에서 기본 템플릿 클래스의 정적 멤버에 액세스할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿