C ++ feclearexcept () - C ++ standardowa biblioteka

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
Maska bitowa akceptuje makra
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

Interesujące artykuły...