Autonome Implementierung des self-Mitgliedstyps in C
C fehlt eine explizite Syntax für das self-Schlüsselwort, wie es in PHP zu finden ist und den Typ bezeichnet der umschließenden Klasse. Traditionell kann dieses Verhalten manuell emuliert werden, indem innerhalb jeder Klasse ein Typedef-Alias definiert wird:
struct Foo { typedef Foo self; };
Dieser Ansatz beinhaltet jedoch die Wiederholung des Klassennamens, was potenzielle Risiken für Nichtübereinstimmungen und Fehler mit sich bringt. Um dies zu beheben, wurde eine alternative Methode vorgeschlagen, die decltype und Freunde nutzt:
struct Foo { typedef decltype(*this) self; };
Leider ist diese Syntax im Kontext von Klassendefinitionen ungültig.
Um eine autonome Implementierung von self zu erreichen ist ein ausgefeilterer Ansatz erforderlich. Mithilfe der Vorlagen-Metaprogrammierung können wir ein Klassenvorlagen-Self definieren, das das Klassenverhalten kapselt und gleichzeitig die Notwendigkeit einer manuellen Typreplikation eliminiert:
template <typename...Ts> class Self; template <typename X, typename...Ts> class Self<X,Ts...> : public Ts... { protected: typedef X self; };
Um diesen Mechanismus zu nutzen, führen wir zwei Makros ein:
#define WITH_SELF(X) X : public Self<X> #define WITH_SELF_DERIVED(X,...) X : public Self<X,__VA_ARGS__>
Mit diesen Makros können wir Klassen mit Self-Member-Typen definieren:
class WITH_SELF(Foo) { void test() { self foo; } };
Für abgeleitete Klassen die Das WITH_SELF_DERIVED-Makro ermöglicht Mehrfachvererbung:
class WITH_SELF_DERIVED(Bar,Foo) { /* ... */ };
Diese Lösung ist sowohl mit gcc 4.8 als auch mit clang 3.4 kompatibel und ermöglicht die autonome Implementierung des Self-Member-Typs in C, ohne dass eine explizite Wiederholung des Klassennamens erforderlich ist.
Das obige ist der detaillierte Inhalt vonWie können wir automatisch einen „Selbst'-Mitgliedstyp in C implementieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!