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

Warum kann ich Gleitkommazahlen nicht als C-Vorlagenparameter verwenden?

Patricia Arquette
Freigeben: 2024-12-10 01:16:09
Original
1075 Leute haben es durchsucht

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
Nach dem Login kopieren

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>();
Nach dem Login kopieren

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!

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