Heim > Backend-Entwicklung > C++ > Wie kann CRTP in C Typedefs aus abgeleiteten Klassen für statischen Polymorphismus verarbeiten?

Wie kann CRTP in C Typedefs aus abgeleiteten Klassen für statischen Polymorphismus verarbeiten?

DDD
Freigeben: 2024-12-10 09:42:18
Original
946 Leute haben es durchsucht

How Can CRTP in C   Handle Typedefs from Derived Classes for Static Polymorphism?

C Static Polymorphism (CRTP) mit Typedefs aus abgeleiteten Klassen

Beim statischen Polymorphismus, auch bekannt als Polymorphismus zur Kompilierungszeit, werden die Typen von Abgeleitete Klassen sind der Basisklasse zur Kompilierungszeit bekannt. Dies kann mithilfe des neugierig wiederkehrenden Vorlagenmusters (CRTP) erreicht werden. Möglicherweise möchten Sie jedoch die Rückgabetypen von Funktionen basierend auf dem abgeleiteten Typ anpassen.

Bedenken Sie den folgenden Code:

template <typename derived_t>
class base {
public:
    typedef typename derived_t::value_type value_type;
    value_type foo() {
        return static_cast<derived_t*>(this)->foo();
    }
};

template <typename T>
class derived : public base<derived<T>> {
public:
    typedef T value_type;
    value_type foo() {
        return T(); //return some T object (assumes T is default constructable)
    }
};
Nach dem Login kopieren

Dieser Code kann jedoch aufgrund der Verwendung von möglicherweise nicht kompiliert werden der Typalias value_type aus der abgeleiteten Klasse innerhalb der Basisklassenvorlage. Der Fehler besteht darin, dass „derived“ unvollständig ist, wenn es als Vorlagenargument für die Basis verwendet wird.

Eine Lösung besteht darin, eine Merkmalsklassenvorlage zu verwenden. Hier ist ein modifiziertes Beispiel:

// Declare a base_traits traits class template:
template <typename derived_t> 
struct base_traits;

// Define the base class that uses the traits:
template <typename derived_t> 
struct base { 
    typedef typename base_traits<derived_t>::value_type value_type;
    value_type base_foo() {
        return base_traits<derived_t>::call_foo(static_cast<derived_t*>(this));
    }
};

// Define the derived class; it can use the traits too:
template <typename T>
struct derived : base<derived<T>> { 
    typedef typename base_traits<derived>::value_type value_type;

    value_type derived_foo() { 
        return value_type(); 
    }
};

// Declare and define a base_traits specialization for derived:
template <typename T> 
struct base_traits<derived<T>> {
    typedef T value_type;

    static value_type call_foo(derived<T>* x) { 
        return x->derived_foo(); 
    }
};
Nach dem Login kopieren

Durch die Spezialisierung von base_traits für jeden abgeleiteten Typ können Sie die erforderlichen Mitglieder (value_type und call_foo) bereitstellen, die für die Basisklassenvorlage erforderlich sind. Dadurch können Sie innerhalb der Basisklassenvorlage auf Typedefs und Funktionen der abgeleiteten Klasse zugreifen und so einen statischen Polymorphismus mit benutzerdefinierten Rückgabetypen erreichen.

Das obige ist der detaillierte Inhalt vonWie kann CRTP in C Typedefs aus abgeleiteten Klassen für statischen Polymorphismus verarbeiten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage