Funkcja feclearexcept () w C ++ próbuje wyczyścić zmiennoprzecinkowe flagi wyjątków określone przez argument excepts.
Funkcja feclearexcept () jest zdefiniowana w pliku nagłówkowym.
feclearexcept () Prototyp
int feclearexcept (int z wyjątkiem);
Aby funkcja działała, należy włączyć FENV_ACCESS , co da programowi dostęp do środowiska zmiennoprzecinkowego w celu przetestowania zgłoszonych wyjątków.
feclearexcept () Parametry
- excepts: Lista flag wyjątków w postaci maski bitowej do wyczyszczenia
Makro | Rodzaj | Opis |
---|---|---|
FE_DIVBYZERO | Błąd Polaka | Dzielenie przez zero |
FE_INEXACT | Niedokładny | Niedokładne wyniki, takie jak (1,0 / 3,0) |
FE_INVALID | Błąd domeny | Przynajmniej jeden użyty argument to wartość, dla której funkcja nie jest zdefiniowana |
FE_OVERFLOW | Błąd zakresu przepełnienia | Wynik jest zbyt duży, aby mógł być reprezentowany przez typ zwracany |
FE_UNDERFLOW | Błąd zakresu niedomiaru | Wynik jest zbyt mały, aby mógł być reprezentowany przez typ zwracany |
FE_ALL_EXCEPT | Wszystkie wyjątki | Wszystkie wyjątki obsługiwane przez implementację |
feclearexcept () Wartość zwracana
- Funkcja feclearexcept () zwraca wartość zerową, jeśli wszystkie wyjątki zostały usunięte lub jeśli wyjątki są równe zero.
- Zwraca wartość różną od zera, jeśli wystąpi jakiś błąd.
Przykład: Jak działa funkcja 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; ) )
Po uruchomieniu programu wynik będzie następujący:
1/0 = ustawiono inf FE_DIVBYZERO sqrt (-1) = -nan ustawiono FE_INVALID