FE_DFL_ENV
Von cppreference.com
| Definiert in Header <cfenv> |
||
| #define FE_DFL_ENV /*implementierungsabhängig*/ |
(seit C++11) | |
Die Makrokonstante FE_DFL_ENV expandiert zu einem Ausdruck vom Typ const std::fenv_t*, der auf eine vollständige Kopie der Standard-Gleitkommaumgebung zeigt, d.h. der Umgebung, wie sie beim Programmstart geladen wurde.
Zusätzliche Makros, die mit FE_ gefolgt von Großbuchstaben beginnen und den Typ const std::fenv_t* haben, können von einer Implementierung unterstützt werden.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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(); }
Ausgabe
On startup: rounding to nearest Before restoration: underflow is raised overflow is raised rounding up After reset to default: rounding to nearest
[bearbeiten] Siehe auch
| (C++11) |
speichert oder stellt die aktuelle Gleitkomma-Umgebung wieder her (function) |
| (C++11) |
stellt die Gleitkomma-Umgebung wieder her und löst die zuvor ausgelösten Ausnahmen aus (function) |
| C-Dokumentation für FE_DFL_ENV
| |