Funkcija feupdateenv () pirmiausia išsaugo šiuo metu iškeltas slankiojo kablelio išimtis, atkuria slankiojo kablelio aplinką iš nurodyto objekto fenv_t, tada kelia anksčiau išsaugotas išimtis.
Funkcija feupdateenv () yra apibrėžta antraštės faile.
feupdateenv () prototipas
int feupdateenv (fenv_t * envp);
Funkcijos feupdateenv () argumentas yra fenv_t tipo žymeklis, kuris turi slankiojo kablelio aplinką, anksčiau nustatytą naudojant feholdexcept arba fegetenv, ir atkuria tą slankiojo kablelio aplinką kartu su dabartine aplinka.
feupdateenv () parametrai
- envp: Fenv_t objekto, kurį nustato ankstesnis kvietimas feholdexcept arba fegetenv, žymeklis arba lygus FE_DFL_ENV.
feupdateenv () Grąžinimo vertė
- Sėkmės atveju funkcija feupdateenv () grąžina 0.
- Po nesėkmės jis pateikia nulį.
Pavyzdys: Kaip veikia feupdateenv () funkcija?
#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; )
Kai paleisite programą, išvestis bus:
Iškeltos išimtys: FE_DIVBYZERO FE_INVALID Iškeltos išimtys: Nėra Paaukštintos išimtys: FE_DIVBYZERO FE_INVALID