Heim > Backend-Entwicklung > C++ > Wie implementiert man eine Vorlagenfunktion, die ihre Implementierung basierend auf der Verfügbarkeit von std::to_string auswählt?

Wie implementiert man eine Vorlagenfunktion, die ihre Implementierung basierend auf der Verfügbarkeit von std::to_string auswählt?

Linda Hamilton
Freigeben: 2024-11-09 08:25:02
Original
641 Leute haben es durchsucht

How to Implement a Template Function That Selects Its Implementation Based on the Availability of std::to_string?

Metaprogrammierung: Funktionsdefinition basierend auf der Typverfügbarkeit ableiten

Im Kontext der Template-Metaprogrammierung wird es notwendig, Vorlagen basierend auf bestimmten Kriterien zu definieren . In diesem speziellen Szenario besteht das Ziel darin, eine Vorlage zu definieren, die ihre Implementierung basierend darauf auswählt, ob die überladene to_string-Funktion für einen bestimmten Typ definiert ist.

Der erste Versuch bestand darin, is_arithmetic als Auswahlkriterium zu verwenden:

template<typename T> enable_if_t<is_arithmetic<T>::value, string> stringify(T t){
    return to_string(t);
}
Nach dem Login kopieren

To_string ist jedoch möglicherweise nicht für nicht-arithmetische Typen verfügbar, was dazu führt, dass eine zusätzliche Vorlage erforderlich ist:

template<typename T> enable_if_t<!is_arithmetic<T>::value, string> stringify(T t){
    return static_cast<ostringstream&>(ostringstream() << t).str();
}
Nach dem Login kopieren

Die Herausforderung bestand darin, die Vorlagenauswahlkriterien für den Fall zu definieren wobei to_string nicht verfügbar ist. Der folgende Versuch war erfolglos:

template<typename T> enable_if_t<!decltype(to_string(T{})::value, string> (T t){
    return static_cast<ostringstream&>(ostringstream() << t).str();
}
Nach dem Login kopieren

Um dieses Problem zu lösen, können wir das von Walter Brown eingeführte Typmerkmal void_t nutzen, das es uns ermöglicht, ein Typmerkmal zu definieren, das die Existenz einer Funktion prüft:

template <typename...>
using void_t = void;
Nach dem Login kopieren

Damit können wir das gewünschte Typmerkmal wie folgt konstruieren:

template<typename T, typename = void>
struct has_to_string
: std::false_type { };

template<typename T>
struct has_to_string<T, 
    void_t<decltype(std::to_string(std::declval<T>()))>
    > 
: std::true_type { };
Nach dem Login kopieren

Mit diesem Typmerkmal können wir anschließend die Vorlage definieren, die ihre Implementierung basierend auf der Verfügbarkeit von auswählt to_string:

template<typename T> 
auto stringify(T t) 
-> std::enable_if_t<has_to_string<T>::value, std::string> 
{
    return std::to_string(t);
}

template<typename T>
auto stringify(T t)
-> std::enable_if_t<!has_to_string<T>::value, std::string> 
{
    return static_cast<ostringstream&amp;>(ostringstream() << t).str();
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie implementiert man eine Vorlagenfunktion, die ihre Implementierung basierend auf der Verfügbarkeit von std::to_string auswählt?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage