C ++ fesetenv () - Bibliothèque standard C ++

La fonction fesetenv () en C ++ tente de définir l'environnement en virgule flottante à partir de l'objet pointeur donné de type fenv_t.

La fonction fesetenv () est définie dans le fichier d'en-tête.

prototype fesetenv ()

 int fesetenv (fenv_t * envp);

La fonction fesetenv () tente de définir l'environnement en virgule flottante à partir de l'objet pointé par envp. La valeur de envp doit être préalablement obtenue par un appel à feholdexcept ou fegetenv ou être une macro constante à virgule flottante.

Paramètres fesetenv ()

  • envp: pointeur vers un objet de type fenv_t qui stocke l'état de l'environnement en virgule flottante.

fesetenv () Valeur de retour

  • En cas de succès, la fonction fesetenv () renvoie 0.
  • En cas d'échec, il renvoie une valeur différente de zéro.

Exemple: Comment fonctionne la fonction fesetenv ()?

 #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; ) void print_current_rounding_direction() ( cout << "Current rounding method: "; switch (fegetround()) ( case FE_TONEAREST: cout << "FE_TONEAREST"; break; case FE_DOWNWARD: cout << "FE_DOWNWARD"; break; case FE_UPWARD: cout << "FE_UPWARD"; break; case FE_TOWARDZERO: cout << "FE_TOWARDZERO"; break; default: cout << "unknown"; ); cout << endl; ) void print_environment() ( print_exceptions(); print_current_rounding_direction(); ) int main(void) ( cout << "Initial environment " << endl; print_environment(); fenv_t envp; /* Save current environment */ fegetenv(&envp); feraiseexcept(FE_INVALID|FE_DIVBYZERO); fesetround(FE_DOWNWARD); cout << "After changing environment " << endl; print_environment(); /* Restores previous environment */ fesetenv(&envp); cout << "Restoring initial environment " << endl; print_environment(); return 0; )

Lorsque vous exécutez le programme, la sortie sera:

 Environnement initial Exceptions levées: Aucune Méthode d'arrondi actuelle: FE_TONEAREST Après changement d'environnement Exceptions levées: FE_DIVBYZERO FE_INVALID Méthode d'arrondi actuelle: FE_DOWNWARD Restauration de l'environnement initial Exceptions levées: Aucune Méthode d'arrondi actuelle: FE_TONEAREST

Articles intéressants...