클래스 템플릿에 대한 멤버 함수의 명시적 특수화
문제 설명:
언제 클래스 템플릿에 대한 멤버 함수의 명시적인 특수화를 정의하려면 주변 클래스 템플릿도 명시적으로 특수화해야 합니다. 컴파일러 오류.
코드 예:
다음 코드 조각을 고려하세요.
template <class C> class X { public: template <class T> void get_as(); }; template <class C> void X<C>::get_as<double>() { } int main() { X<int> x; x.get_as(); }
이 코드는 주변 클래스 템플릿 X 명시적으로는 아니다
해결책:
이 문제를 해결하려면 아래와 같이 주변 클래스 템플릿을 명시적으로 특수화해야 합니다.
template <> template <> void X<int>::get_as<double>() { }
이것은 특수 멤버 함수는 X
대체 접근 방식:
대체 접근 방식은 다음 코드에서 볼 수 있듯이 함수 오버로드를 사용하는 것입니다.
template <class C> class X { template<typename T> struct type { }; public: template <class T> void get_as() { get_as(type<T>()); } private: template<typename T> void get_as(type<T>) {} void get_as(type<double>) {} };
이 방법을 사용하면 주변 클래스 템플릿을 특수화할 필요 없이 명시적으로 특수화할 수 있습니다.
위 내용은 클래스 템플릿의 멤버 함수를 명시적으로 특수화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!