Namespaces
Variants

FE_DIVBYZERO, FE_INEXACT, FE_INVALID, FE_OVERFLOW, FE_UNDERFLOW, FE_ALL_EXCEPT

From cppreference.net
Floating-point environment
Functions
(C++11) (C++11)
(C++11) (C++11)
Macro constants
FE_ALL_EXCEPT FE_DIVBYZERO FE_INEXACT FE_INVALID FE_OVERFLOW FE_UNDERFLOW
(C++11) (C++11) (C++11) (C++11) (C++11) (C++11)
(C++11)
Definiert im Header <cfenv>
#define FE_DIVBYZERO    /*implementation defined power of 2*/
(seit C++11)
#define FE_INEXACT      /*implementation defined power of 2*/
(seit C++11)
#define FE_INVALID      /*implementation defined power of 2*/
(seit C++11)
#define FE_OVERFLOW     /*implementation defined power of 2*/
(seit C++11)
#define FE_UNDERFLOW    /*implementation defined power of 2*/
(seit C++11)
#define FE_ALL_EXCEPT   FE_DIVBYZERO | FE_INEXACT | \

FE_INVALID | FE_OVERFLOW |  \

FE_UNDERFLOW
(seit C++11)

Alle diese Makrokonstanten (außer FE_ALL_EXCEPT ) erweitern zu ganzzahligen konstanten Ausdrücken, die unterschiedliche Zweierpotenzen sind und alle unterstützten Gleitkomma-Ausnahmen eindeutig identifizieren. Jedes Makro ist nur definiert, wenn es unterstützt wird.

Die Makrokonstante FE_ALL_EXCEPT , die sich zur bitweisen ODER-Verknüpfung aller anderen FE_* -Makros erweitert, ist immer definiert und ist null, wenn Gleitkomma-Ausnahmen von der Implementierung nicht unterstützt werden.

Konstante Erklärung
FE_DIVBYZERO Polstellenfehler trat bei einer früheren Gleitkommaoperation auf
FE_INEXACT Ungenauiges Ergebnis: Rundung war notwendig, um das Ergebnis einer früheren Gleitkommaoperation zu speichern
FE_INVALID Definitionsbereichsfehler trat bei einer früheren Gleitkommaoperation auf
FE_OVERFLOW Das Ergebnis der früheren Gleitkommaoperation war zu groß, um darstellbar zu sein
FE_UNDERFLOW Das Ergebnis der früheren Gleitkommaoperation war subnormal mit Genauigkeitsverlust
FE_ALL_EXCEPT Bitweises ODER aller unterstützten Gleitkomma-Ausnahmen

Die Implementierung kann zusätzliche Makrokonstanten in <cfenv> definieren, um zusätzliche Gleitkomma-Ausnahmen zu identifizieren. Alle diese Konstanten beginnen mit FE_ gefolgt von mindestens einem Großbuchstaben.

Siehe math_errhandling für weitere Details.

Beispiel

#include <cfenv>
#include <cmath>
#include <iostream>
// #pragma STDC FENV_ACCESS ON
volatile double zero = 0.0; // volatile not needed where FENV_ACCESS is supported
volatile double one = 1.0;  // volatile not needed where FENV_ACCESS is supported
int main()
{
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout <<  "1.0/0.0 = " << 1.0 / zero << '\n';
    if (std::fetestexcept(FE_DIVBYZERO))
        std::cout << "division by zero reported\n";
    else
        std::cout << "division by zero not reported\n";
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout << "1.0/10 = " << one / 10 << '\n';
    if (std::fetestexcept(FE_INEXACT))
        std::cout << "inexact result reported\n";
    else
        std::cout << "inexact result not reported\n";
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout << "sqrt(-1) = " << std::sqrt(-1) << '\n';
    if (std::fetestexcept(FE_INVALID))
        std::cout << "invalid result reported\n";
    else
        std::cout << "invalid result not reported\n";
}

Mögliche Ausgabe:

1.0/0.0 = inf
division by zero reported
1.0/10 = 0.1
inexact result reported
sqrt(-1) = -nan
invalid result reported

Siehe auch

Definiert den Fehlerbehandlungsmechanismus, der von den allgemeinen mathematischen Funktionen verwendet wird
(Makrokonstante)
C-Dokumentation für Gleitkomma-Ausnahmemakros