Funkcija feupdateenv () najprej shrani trenutno postavljene izjeme s plavajočo vejico, obnovi okolje s plavajočo vejico iz danega predmeta fenv_t, nato poviša prej shranjene izjeme.
Funkcija feupdateenv () je definirana v datoteki glave.
prototip feupdateenv ()
int feupdateenv (fenv_t * envp);
Funkcija feupdateenv () za argument vzame kazalec tipa fenv_t, ki vsebuje okolje s plavajočo vejico, ki je bilo predhodno nastavljeno s pomočjo feholdexcept ali fegetenv, in obnavlja to okolje s plavajočo vejico skupaj s trenutnim okoljem.
parametri feupdateenv ()
- envp: Kazalec na objekt fenv_t, ki je nastavljen s prejšnjim klicem na feholdexcept ali fegetenv ali je enak FE_DFL_ENV.
feupdateenv () Vrnjena vrednost
- Po uspehu funkcija feupdateenv () vrne 0.
- Ob neuspehu vrne ničlo.
Primer: Kako deluje funkcija 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; )
Ko zaženete program, bo rezultat:
Povečane izjeme: FE_DIVBYZERO FE_INVALID Povišane izjeme: Brez Povišane izjeme: FE_DIVBYZERO FE_INVALID