Heim >Backend-Entwicklung >C++ >Warum schlägt die explizite Spezialisierung von Klassenmitgliedern außerhalb eines Namespace in C fehl?
Explizite Spezialisierung außerhalb des Namespace-Geltungsbereichs: Ein Fehler in der nicht standardmäßigen G
C-Vorlagenprogrammierung beinhaltet die explizite Spezialisierung von Klassenmitgliedern für effizienten Code Generation. Die Platzierung expliziter Spezialisierungen ist jedoch entscheidend, wie das folgende Code-Snippet zeigt:
template<typename T> class CConstraint { // ... template <typename TL> void Verify(int position, int constraints[]) { } template <> void Verify<int>(int, int[]) { } };
Beim Kompilieren mit g führt dieser Code zu dem Fehler:
Explicit specialization in non-namespace scope 'class CConstraint'
Zum Verständnis Um diesen Fehler zu beheben, müssen wir den C-Standard untersuchen, der vorschreibt, dass explizite Spezialisierungen innerhalb des Namespace deklariert werden müssen, dessen Mitglied die Vorlage ist. Im obigen Beispiel wird CConstraint in keinem Namespace deklariert und daher ist die explizite Spezialisierung von Verify
VC-Compiler sind in diesem Fall jedoch nicht konform und erlauben explizite Spezialisierungen außerhalb des Namespace-Bereichs. Dieses Verhalten ist nicht standardmäßig und sollte nicht als verlässlich angesehen werden.
Lösung:
Um dieses Problem zu beheben und die Einhaltung des C-Standards sicherzustellen, müssen explizite Spezialisierungen deklariert werden innerhalb desselben Namensraums wie die Vorlage, auf die sie spezialisiert sind. Hier ist eine korrigierte Version des Codes:
namespace MyNamespace { template<typename T> class CConstraint { // ... template <typename TL> void Verify(int position, int constraints[]) { } template <> void Verify<int>(int, int[]) { } }; }
Durch die Kapselung von CConstraint innerhalb des MyNamespace-Namespace stellen wir sicher, dass seine expliziten Spezialisierungen auch innerhalb dieses Namespace deklariert werden, wodurch der Kompilierungsfehler behoben wird.
Da C 03 außerdem die Spezialisierung von Mitgliedsfunktionen ohne explizite Spezialisierung der enthaltenden Klasse verbietet, könnten wir auch die Verwendung eines Ansatzes mit freien Funktionen in Betracht ziehen, wie im bereitgestellten Vorschlag vorgeschlagen Antwort:
namespace detail { template <typename TL> void Verify(int, int[]) {} template <> void Verify<int>(int, int[]) {} } template<typename T> class CConstraint { // ... template <typename TL> void Verify(int position, int constraints[]) { detail::Verify<TL>(position, constraints); } };
Das obige ist der detaillierte Inhalt vonWarum schlägt die explizite Spezialisierung von Klassenmitgliedern außerhalb eines Namespace in C fehl?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!