Funkcja feholdexcept () w C ++ najpierw zapisuje bieżące środowisko zmiennoprzecinkowe do obiektu fenv_t, a następnie czyści wszystkie flagi stanu zmiennoprzecinkowego.
Funkcja feholdexcept () jest zdefiniowana w pliku nagłówkowym.
prototyp feholdexcept ()
int feholdexcept (fenv_t * envp);
Funkcja feholdexcept () zapisuje bieżące środowisko zmiennoprzecinkowe do obiektu wskazywanego przez envp, tak jak zostało to zrobione przez fegetenv () i czyści wszystkie flagi stanu zmiennoprzecinkowego.
Na koniec instaluje tryb non-stop, aby przyszłe wyjątki zmiennoprzecinkowe nie przerywały wykonywania, dopóki środowisko zmiennoprzecinkowe nie zostanie przywrócone przez wywołanie feupdateenv lub fesetenv.
feholdexcept () Parametry
- envp: wskaźnik do obiektu typu fenv_t, który przechowuje stan środowiska zmiennoprzecinkowego.
feholdexcept () Wartość zwracana
- Po pomyślnym zakończeniu funkcja feholdexcept () zwraca 0.
- W przypadku niepowodzenia zwraca wartość różną od zera.
Przykład: Jak działa funkcja feholdexcept ()?
#include #include #include #pragma STDC FENV_ACCESS ON using namespace std; void print_exceptions() ( cout << "Raised exceptions: "; if(fetestexcept(FE_ALL_EXCEPT)) ( if(fetestexcept(FE_DIVBYZERO)) cout << "FE_DIVBYZERO "; if(fetestexcept(FE_INEXACT)) cout << "FE_INEXACT "; if(fetestexcept(FE_INVALID)) cout << "FE_INVALID "; if(fetestexcept(FE_OVERFLOW)) cout << "FE_OVERFLOW "; if(fetestexcept(FE_UNDERFLOW)) cout << "FE_UNDERFLOW "; ) else cout << "None"; cout << endl; ) int main(void) ( fenv_t envp; /* raise certain exceptions */ feraiseexcept(FE_INVALID|FE_DIVBYZERO); print_exceptions(); /* saves and clears current exceptions */ feholdexcept(&envp); print_exceptions(); /* restores saved exceptions */ feupdateenv(&envp); print_exceptions(); return 0; )
Po uruchomieniu programu wynik będzie następujący:
Zgłoszone wyjątki: FE_DIVBYZERO FE_INVALID Zgłoszone wyjątki: Brak Zgłoszone wyjątki: FE_DIVBYZERO FE_INVALID