La fonction feupdateenv () enregistre d'abord les exceptions en virgule flottante actuellement levées, restaure l'environnement en virgule flottante à partir de l'objet fenv_t donné, puis lève les exceptions enregistrées précédemment.
La fonction feupdateenv () est définie dans le fichier d'en-tête.
prototype feupdateenv ()
int feupdateenv (fenv_t * envp);
La fonction feupdateenv () prend comme argument un pointeur de type fenv_t qui contient un environnement en virgule flottante précédemment défini en utilisant feholdexcept ou fegetenv et restaure cet environnement en virgule flottante avec l'environnement actuel.
Paramètres de feupdateenv ()
- envp: pointeur vers l'objet fenv_t défini par un appel antérieur à feholdexcept ou fegetenv ou est égal à FE_DFL_ENV.
feupdateenv () Valeur de retour
- En cas de succès, la fonction feupdateenv () renvoie 0.
- En cas d'échec, il renvoie une valeur différente de zéro.
Exemple: Comment fonctionne la fonction 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; )
Lorsque vous exécutez le programme, la sortie sera:
Exceptions déclenchées: FE_DIVBYZERO FE_INVALID Exceptions déclenchées: aucune Exceptions déclenchées: FE_DIVBYZERO FE_INVALID