>백엔드 개발 >C++ >C 정적 다형성(CRTP)을 사용하여 유연한 반환 유형을 달성하고 컴파일 오류를 방지하려면 어떻게 해야 합니까?

C 정적 다형성(CRTP)을 사용하여 유연한 반환 유형을 달성하고 컴파일 오류를 방지하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-09 00:04:15803검색

How Can I Achieve Flexible Return Types with C   Static Polymorphism (CRTP) and Avoid Compilation Errors?

파생 클래스 형식 정의를 사용하는 C 정적 다형성(CRTP)

이상하게 반복되는 템플릿 패턴(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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.