Функцията feupdateenv () първо съхранява повдигнатите в момента изключения с плаваща запетая, възстановява средата с плаваща запетая от дадения обект fenv_t, след което издига изключенията, запазени преди това.
Функцията feupdateenv () е дефинирана в заглавния файл.
feupdateenv () прототип
int feupdateenv (fenv_t * envp);
Функцията feupdateenv () приема като аргумент указател от тип fenv_t, който съдържа среда с плаваща запетая, предварително зададена с помощта на feholdexcept или fegetenv, и възстановява тази среда с плаваща запетая заедно с текущата среда.
feupdateenv () Параметри
- envp: Указател към обекта fenv_t, който е зададен от по-ранно извикване на feholdexcept или fegetenv или е равен на FE_DFL_ENV.
feupdateenv () Върната стойност
- При успех функцията feupdateenv () връща 0.
- При неуспех се връща ненулево.
Пример: Как работи функцията 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; )
Когато стартирате програмата, изходът ще бъде:
Повишени изключения: FE_DIVBYZERO FE_INVALID Повишени изключения: Няма Повишени изключения: FE_DIVBYZERO FE_INVALID