Heim >Backend-Entwicklung >C++ >Warum kann ich Gleitkommazahlen nicht als C-Vorlagenparameter verwenden?

Warum kann ich Gleitkommazahlen nicht als C-Vorlagenparameter verwenden?

Patricia Arquette
Patricia ArquetteOriginal
2024-12-10 01:16:091074Durchsuche

Why Can't I Use Floating-Point Numbers as C   Template Parameters?

Warum Gleitkommawerte nicht als Vorlagenparameter zulässig sind

In C wird versucht, einen Gleitkommawert als Vorlagenparameter zu verwenden, wie in Der folgende Code führt zu folgendem Fehler:

GenericClass<float, 4.6f> gcFloat;
error: `float' is not a valid type for a template constant parameter

Standard Verbot

Gemäß dem C 11-Standard müssen Nicht-Typ-Template-Argumente eines der folgenden sein:

  • Konvertierte konstante Ausdrücke von Integral- oder Aufzählungstypen
  • Nicht-Typ-Vorlagenparameternamen
  • Ausdrücke, die Adressen von statischen Objekten bezeichnen oder Funktionen
  • Nullzeiger
  • Nullelementzeiger
  • Zeiger auf Elemente

Gleitkommawerte passen jedoch in keine dieser Kategorien .

Begründung

Die primäre Grund für diese Einschränkung ist die Ungenauigkeit von Gleitkommaberechnungen. Gleitkommaberechnungen können nicht exakt dargestellt werden, was bei der Verwendung als Vorlagenargumente zu unerwartetem Verhalten führen kann. Beispielsweise verhält sich der folgende Code aufgrund möglicher Rundungsunterschiede möglicherweise nicht wie beabsichtigt:

func<1/3.f>();
func<2/6.f>();

Alternative Lösungen

Berücksichtigen Sie die Darstellung von Gleitkommawerten als Vorlagenargumente Verwenden erweiterter Konstantenausdrücke (constexpr) in C 11, um den Zähler und Nenner des Gleitkommawerts zur Kompilierungszeit zu berechnen. Diese können dann als separate Ganzzahlargumente übergeben werden. Es ist jedoch wichtig, einen Schwellenwert zu definieren, um sicherzustellen, dass nahe beieinander liegende Gleitkommawerte das gleiche Zähler/Nenner-Verhältnis ergeben.

Das obige ist der detaillierte Inhalt vonWarum kann ich Gleitkommazahlen nicht als C-Vorlagenparameter verwenden?. 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