Funkce feupdateenv () nejprve uloží aktuálně vyvolané výjimky s plovoucí desetinnou čárkou, obnoví prostředí s plovoucí desetinnou čárkou z daného objektu fenv_t a poté vyvolá dříve uložené výjimky.
Funkce feupdateenv () je definována v hlavičkovém souboru.
prototyp feupdateenv ()
int feupdateenv (fenv_t * envp);
Funkce feupdateenv () přebírá ukazatel typu fenv_t jako svůj argument, který obsahuje prostředí s plovoucí desetinnou čárkou dříve nastavené pomocí feholdexcept nebo fegetenv a obnovuje toto prostředí s plovoucí desetinnou čárkou spolu s aktuálním prostředím.
feupdateenv () Parametry
- envp: Ukazatel na objekt fenv_t, který je nastaven dřívějším voláním feholdexcept nebo fegetenv nebo se rovná FE_DFL_ENV.
feupdateenv () Návratová hodnota
- Při úspěchu funkce feupdateenv () vrací 0.
- Při selhání vrátí nenulovou hodnotu.
Příklad: Jak funguje funkce feupdateenv ()?
#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() ( fenv_t envp; /* raise certain exceptions */ feraiseexcept(FE_INVALID|FE_DIVBYZERO); print_exceptions(); /* saves and clears current exceptions */ feupdateenv(&envp); print_exceptions(); /* restores saved exceptions */ feupdateenv(&envp); print_exceptions(); return 0; )
Když spustíte program, výstup bude:
Zvýšené výjimky: FE_DIVBYZERO FE_INVALID Zvýšené výjimky: Žádné Zvýšené výjimky: FE_DIVBYZERO FE_INVALID