명시적으로 특수화된 멤버 함수가 있는 템플릿 클래스
클래스 템플릿의 멤버 함수에 대한 명시적 특수화를 정의할 때 다음과 같은 일반적인 함정이 발생합니다. 주변 클래스 템플릿도 템플릿입니다. 문제를 이해하려면 다음 예를 고려하십시오.
#include <iostream> #include <cmath> template <class C> class X { public: template <class T> void get_as(); }; template <class C> void X<C>::get_as<double>() {} // Explicit specialization for double int main() { X<int> x; x.get_as(); }
이 코드는 X 클래스 템플릿의 double에 대한 get_as 멤버 함수를 명시적으로 특수화하려고 시도합니다. 그러나 이 접근 방식은 주변 클래스 템플릿이 명시적으로 특수화되지 않았기 때문에 컴파일러 오류가 발생합니다.
잘못된 접근 방식:
클래스를 특수화하지 않고 멤버 함수를 명시적으로 특수화하려고 시도함 템플릿은 아래와 같습니다. 잘못됨:
template <class C> template<> void X<C>::get_as<double>() {}
올바른 해결책:
문제를 해결하려면 클래스 템플릿과 멤버 함수가 모두 명시적으로 특수화되어야 합니다. 예를 들어 X
template <> template <class T> void X<int>::get_as() {} template <> void X<int>::get_as<double>() {}
대체 옵션:
또는 주변을 유지하려면 클래스 템플릿이 특수화되지 않은 경우 다음과 같이 get_as 함수의 오버로드를 사용할 수 있습니다. 코드:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!