FE_DFL_ENV
|
Défini dans l'en-tête
<cfenv>
|
||
|
#define FE_DFL_ENV /*implementation defined*/
|
(depuis C++11) | |
La constante macro
FE_DFL_ENV
se développe en une expression de type
const
std::
fenv_t
*
, qui pointe vers une copie complète de l'environnement à virgule flottante par défaut, c'est-à-dire l'environnement tel que chargé au démarrage du programme.
Des macros supplémentaires qui commencent par
FE_
suivies de lettres majuscules, et qui ont le type
const
std::
fenv_t
*
, peuvent être prises en charge par une implémentation.
Exemple
#include <cfenv> #include <iostream> // #pragma STDC FENV_ACCESS ON void show_env() { const int e = std::fetestexcept(FE_ALL_EXCEPT); if (e & FE_DIVBYZERO) std::cout << "division by zero is raised\n"; if (e & FE_INEXACT) std::cout << "inexact is raised\n"; if (e & FE_INVALID) std::cout << "invalid is raised\n"; if (e & FE_UNDERFLOW) std::cout << "underflow is raised\n"; if (e & FE_OVERFLOW) std::cout << "overflow is raised\n"; switch (std::fegetround()) { case FE_DOWNWARD: std::cout << "rounding down\n"; break; case FE_TONEAREST: std::cout << "rounding to nearest\n"; break; case FE_TOWARDZERO: std::cout << "rounding to zero\n"; break; case FE_UPWARD: std::cout << "rounding up\n"; break; } } int main() { std::cout << "On startup:\n"; show_env(); std::feraiseexcept(FE_UNDERFLOW | FE_OVERFLOW); std::fesetround(FE_UPWARD); std::cout << "\nBefore restoration:\n"; show_env(); std::fesetenv(FE_DFL_ENV); std::cout << "\nAfter reset to default:\n"; show_env(); }
Sortie :
Au démarrage : arrondi au plus proche Avant restauration : underflow est levé overflow est levé arrondi vers le haut Après réinitialisation par défaut : arrondi au plus proche
Voir aussi
|
(C++11)
|
sauvegarde ou restaure l'environnement de virgule flottante actuel
(fonction) |
|
(C++11)
|
restaure l'environnement de virgule flottante et lève les exceptions précédemment déclenchées
(fonction) |
|
documentation C
pour
FE_DFL_ENV
|
|