GCC의 템플릿 인수 종속성의 엄격한 적용
제시된 코드는 GCC를 사용할 때 발생하는 문제를 제기하지만 Visual Studio에서는 발생하지 않습니다. 다음 코드는
<code class="cpp">template <typename T> class A { public: T foo; }; template <typename T> class B: public A<T> { public: void bar() { cout << foo << endl; } };
GCC에서는 컴파일에 실패하지만 Visual Studio에서는 성공적으로 컴파일됩니다. 오류는 개발자에게 this->를 추가하라는 메시지를 표시합니다. 메소드 표시줄 내에서 foo 멤버에 액세스하기 위한 표현식입니다.
이 동작은 GCC가 C 사양을 엄격하게 준수하는 데서 비롯됩니다. 이전 버전의 GCC에서는 템플릿 기본 클래스를 구문 분석하여 멤버 액세스를 유추했습니다. 그러나 ISO C는 이 추론을 잠재적으로 문제가 있는 것으로 간주하여 더 이상 사용하지 않습니다.
이 시나리오의 해결책은 this->를 사용하여 foo 멤버를 명시적으로 참조하는 것입니다. 또는 다음 예와 같이 기본 클래스를 명시적으로 지정합니다.
<code class="cpp">template <typename T> class A { public: T foo; }; template <typename T> class B: public A<T> { public: void bar() { cout << A<T>::foo << endl; } };</code>
이렇게 하면 GCC는 기본 클래스의 유형을 결정하고 멤버 액세스를 적절하게 해결할 수 있습니다.
위 내용은 GCC가 템플릿 기본 클래스 멤버에 대해 명시적인 멤버 액세스를 요구하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!