Heim >Backend-Entwicklung >C++ >C++-Funktionsvorlagen kombiniert mit SFINAE (Typableitung nicht gültig)?

C++-Funktionsvorlagen kombiniert mit SFINAE (Typableitung nicht gültig)?

WBOY
WBOYOriginal
2024-04-15 11:39:01934Durchsuche

Funktionsvorlage Wird in Verbindung mit SFINAE verwendet, um generische Funktionen zu erstellen und das Funktionsverhalten basierend auf Vorlagenparametertypen anzupassen. Mit SFINAE können wir die Funktionsverfügbarkeit basierend darauf steuern, ob die Ableitung des Vorlagenparametertyps fehlschlägt. Bei gemeinsamer Verwendung können Funktionsvorlagen das Verhalten basierend auf Typbeschränkungen verfeinern, z. B. durch die Unterscheidung zwischen ganzzahligen und nicht ganzzahligen Typen, den Ausschluss boolescher Typen usw., was zu flexiblem und typsicherem Code führt.

C++ 函数模板与 SFINAE(类型推导失败有效)的结合使用?

Verwendung von C++-Funktionsvorlagen mit SFINAE

Einführung

C++-Funktionsvorlagen ermöglichen es uns, generische Funktionen zu erstellen, die auf vielen verschiedenen Typen funktionieren. In einigen Fällen möchten wir jedoch möglicherweise das Funktionsverhalten basierend auf der Art der Vorlagenparameter verfeinern. Hier kommt SFINAE (Type Deduction Failed Efficient) ins Spiel.

SFINAE

SFINAE ist eine Technik, die es uns ermöglicht, die Verfügbarkeit einer Funktion basierend auf dem Vorhandensein oder Fehlen eines Vorlagenparametertyps zu entscheiden. Wenn ein Vorlagenargument nicht abgeleitet werden kann, meldet der Compiler einen Ableitungsfehler, den wir zur Steuerung der Funktionsverfügbarkeit verwenden können.

Kombinierte Verwendung von C++-Funktionsvorlagen und SFINAE

Wir können die Funktionalität von Funktionsvorlagen durch die Verwendung von SFINAE erweitern. Schauen wir uns ein Beispiel an:

template <typename T>
typename std::enable_if<std::is_integral<T>::value, void>::type func(T x) {
  // Integral type-specific implementation
}

template <typename T>
typename std::enable_if<!std::is_integral<T>::value, void>::type func(T x) {
  // Non-integral type-specific implementation
}

In diesem Beispiel erstellen wir eine Funktionsvorlage func und wählen verschiedene Funktionssignaturen basierend auf dem Typ des Vorlagenparameters T aus. Mit std::enable_if erstellen wir zwei verschachtelte Funktionen, die nur verfügbar sind, wenn bestimmte Typbeschränkungen erfüllt sind. Bei ganzzahligen Typen wird die erste Funktion aufgerufen, bei nicht ganzzahligen Typen wird die zweite Funktion aufgerufen. func,根据模板参数 T 的类型选择不同的函数签名。使用 std::enable_if,我们创建两个嵌套函数,它们仅在满足特定类型约束时可用。对于整数类型,将调用第一个函数,对于非整数类型,将调用第二个函数。

实战案例

以下是一个 C++ 函数模板与 SFINAE 结合使用的实际案例:

// 实现求平方和的函数模板
template <typename T>
auto sum_of_squares(const std::vector<T>& v) {
  typename std::enable_if<!std::is_same<T, bool>::value, decltype(v[0]*v[0])>::type result = T{};

  for (const auto& elem : v)
    result += elem * elem;

  return result;
}

在这个案例中,我们创建了一个函数模板 sum_of_squares

Praktischer Fall

Das Folgende ist ein praktischer Fall der Verwendung von C++-Funktionsvorlagen mit SFINAE:

rrreee

In diesem Fall haben wir eine Funktionsvorlage sum_of_squares erstellt, die den Vektor „Die Summe von“ löst die Quadrate aller Elemente. Bei Verwendung von SFINAE schließen wir den Typ Boolean aus, da er keine quadratischen Operationen unterstützt. 🎜🎜🎜Fazit🎜🎜🎜C++-Funktionsvorlagen in Kombination mit SFINAE bieten ein leistungsstarkes Tool, das uns bei der Erstellung flexiblen und typsicheren generischen Codes helfen kann. Durch die Nutzung von Vorlagenparametertypen können wir das Funktionsverhalten zur Laufzeit basierend auf Typeinschränkungen verfeinern. Dadurch können wir effizienten und skalierbaren Code schreiben. 🎜

Das obige ist der detaillierte Inhalt vonC++-Funktionsvorlagen kombiniert mit SFINAE (Typableitung nicht gültig)?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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