C ++ feclearexcept () - C ++ Standardbibliothek

Die Funktion feclearexcept () in C ++ versucht, die durch die Argumentausnahmen angegebenen Gleitkomma-Ausnahmeflags zu löschen.

Die Funktion feclearexcept () ist in der Header-Datei definiert.

feclearexcept () Prototyp

 int feclearexcept (int excepts);

Damit die Funktion funktioniert, sollten Sie FENV_ACCESS aktivieren , damit Ihr Programm auf die Gleitkommaumgebung zugreifen kann, um die ausgelösten Ausnahmen zu testen.

feclearexcept () Parameter

  • Ausnahmen: Bitmaskenliste der zu löschenden Ausnahmeflags
Bitmaske akzeptierte Makros
Makro Art Beschreibung
FE_DIVBYZERO Pole Fehler Durch Null teilen
FE_INEXACT Ungenau Nicht genaue Ergebnisse wie (1.0 / 3.0)
FE_INVALID Domänenfehler Mindestens ein Argument ist ein Wert, für den die Funktion nicht definiert ist
FE_OVERFLOW Überlaufbereichsfehler Das Ergebnis ist zu groß, um durch den Rückgabetyp dargestellt zu werden
FE_UNDERFLOW Unterlaufbereichsfehler Das Ergebnis ist zu klein, um durch den Rückgabetyp dargestellt zu werden
FE_ALL_EXCEPT Alle Ausnahmen Alle von der Implementierung unterstützten Ausnahmen

feclearexcept () Rückgabewert

  • Die Funktion feclearexcept () gibt den Wert Null zurück, wenn alle Ausnahmen gelöscht wurden oder wenn Ausnahmen gleich Null sind.
  • Es wird ungleich Null zurückgegeben, wenn ein Fehler auftritt.

Beispiel: Wie funktioniert die Funktion feclearexcept ()?

 #include #include #include #pragma STDC FENV_ACCESS ON using namespace std; int main() ( // clears all exceptions feclearexcept(FE_ALL_EXCEPT); cout << "1/0 = " << 1.0/0.0 << endl; // tests if above statement raised the FE_DIVBYZERO exception if(fetestexcept(FE_DIVBYZERO)) ( cout << "FE_DIVBYZERO is set" << endl; ) else ( cout << "FE_DIVBYZERO is not set" << endl; ) feclearexcept(FE_ALL_EXCEPT); cout << "sqrt(-1) = " << sqrt(-1) << endl; if(fetestexcept(FE_INVALID)) ( cout << "FE_INVALID is set" << endl; ) else ( cout << "FE_INVALID is not set" << endl; ) )

Wenn Sie das Programm ausführen, lautet die Ausgabe wie folgt:

 1/0 = inf FE_DIVBYZERO wird gesetzt sqrt (-1) = -nan FE_INVALID wird gesetzt

Interessante Beiträge...