Funktsioon feupdateenv () salvestab kõigepealt praegu tõstetud ujukomaerandid, taastab ujukoma keskkonna antud objektist fenv_t ja tõstab seejärel varem salvestatud erandid.
Funktsioon feupdateenv () on määratletud päisefailis.
feupdateenv () prototüüp
int feupdateenv (fenv_t * envp);
Funktsioon feupdateenv () võtab argumendiks osuti fenv_t, mis hoiab feholdexcepti või fegetenv abil eelnevalt seatud ujukoma keskkonda ja taastab selle ujukoma keskkonna koos praeguse keskkonnaga.
feupdateenv () parameetrid
- envp: Objekti fenv_t osuti, mille on määranud varasem kõne feholdexcept või fegetenv või mis on võrdne FE_DFL_ENV.
feupdateenv () Tagastusväärtus
- Edu korral tagastab funktsioon feupdateenv () 0.
- Ebaõnnestumisel tagastatakse null.
Näide: Kuidas funktsioon feupdateenv () töötab?
#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; )
Programmi käivitamisel on väljund järgmine:
Tõstetud erandid: FE_DIVBYZERO FE_INVALID Tõstetud erandid: Puuduvad Tõstetud erandid: FE_DIVBYZERO FE_INVALID