Namespaces
Variants

FE_DFL_ENV

From cppreference.net
Floating-point environment
Functions
(C++11) (C++11)
(C++11) (C++11)
Macro constants
FE_DFL_ENV
(C++11)
Definiert im Header <cfenv>
#define FE_DFL_ENV /*implementation defined*/
(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, das heißt, die Umgebung, wie sie beim Programmstart geladen wird.

Zusätzliche Makros, die mit FE_ beginnen, gefolgt von Großbuchstaben, und den Typ const std:: fenv_t * haben, können von einer Implementierung unterstützt werden.

Beispiel

#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

Siehe auch

speichert oder stellt die aktuelle Gleitkommaumgebung wieder her
(Funktion)
stellt die Gleitkommaumgebung wieder her und löst die zuvor ausgelösten Ausnahmen aus
(Funktion)
C-Dokumentation für FE_DFL_ENV