Funcția feupdateenv () salvează mai întâi excepțiile în virgulă mobilă ridicate în prezent, restabilește mediul în virgulă mobilă din obiectul fenv_t dat, apoi ridică excepțiile salvate anterior.
Funcția feupdateenv () este definită în fișierul antet.
prototip feupdateenv ()
int feupdateenv (fenv_t * envp);
Funcția feupdateenv () ia ca indicator un pointer de tip fenv_t care deține un mediu în virgulă mobilă setat anterior utilizând feholdexcept sau fegetenv și restabilește acel mediu în virgulă mobilă împreună cu mediul curent.
feupdateenv () Parametri
- envp: Pointer către obiectul fenv_t care este setat de un apel anterior la feholdexcept sau fegetenv sau este egal cu FE_DFL_ENV.
feupdateenv () Valoare returnată
- La succes, funcția feupdateenv () returnează 0.
- La eșec, se întoarce diferit de zero.
Exemplu: Cum funcționează funcția 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; )
Când rulați programul, ieșirea va fi:
Excepții crescute: FE_DIVBYZERO FE_INVALID Excepții crescute: Niciuna Excepții crescute: FE_DIVBYZERO FE_INVALID