이상하게 반복되는 템플릿 패턴(CRTP)은 C에서 정적 다형성을 허용하지만 목표로 하면 어려워집니다. 파생된 유형을 기반으로 함수 반환 유형을 수정합니다. CRTP는 일반적으로 파생 형식을 유추할 수 있지만 다음 코드에서는 MSVC 2010에서 컴파일 문제가 발생합니다.
template <typename derived_t> class base { public: typedef typename derived_t::value_type value_type; }; template <typename T> class derived : public base<derived<T>> { public: typedef T value_type; };
이 오류는 파생 클래스가 기본 클래스에 대한 템플릿 매개 변수로 사용될 때 불완전하기 때문에 발생합니다. 수업 목록. 이 문제를 해결하기 위한 일반적인 해결 방법은 특성 클래스 템플릿을 사용하는 것입니다.
// Declare the base_traits class template template <typename derived_t> struct base_traits; // Define the base class template <typename derived_t> struct base { typedef typename base_traits<derived_t>::value_type value_type; }; // Define the derived class template <typename T> struct derived : public base<derived<T>> { typedef typename base_traits<derived<T>>::value_type value_type; }; // Specialization of base_traits for derived template <typename T> struct base_traits<derived<T>> { typedef T value_type; };
원하는 파생 유형에 대해 base_traits 템플릿을 특수화하여 foo와 같은 함수에 대한 사용자 정의 반환 유형을 포함하여 필수 멤버를 정의할 수 있습니다. (). 이 기술을 사용하면 컴파일 오류를 방지하면서 반환 유형에 더 많은 유연성을 제공하는 정적 다형성이 가능해집니다.
위 내용은 C 정적 다형성(CRTP)을 사용하여 유연한 반환 유형을 달성하고 컴파일 오류를 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!