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