feholdexcept
|
Definiert im Header
<fenv.h>
|
||
|
int
feholdexcept
(
fenv_t
*
envp
)
;
|
(seit C99) | |
Zuerst speichert es die aktuelle Gleitkommaumgebung in das Objekt, auf das
envp
zeigt (ähnlich wie
fegetenv
), löscht dann alle Gleitkomma-Statusflags und aktiviert den Non-Stop-Modus: zukünftige Gleitkomma-Ausnahmen unterbrechen die Ausführung nicht (werden nicht trapped), bis die Gleitkommaumgebung durch
feupdateenv
oder
fesetenv
wiederhergestellt wird.
Diese Funktion kann am Anfang einer Unterroutine verwendet werden, die Gleitkomma-Ausnahmen, die sie möglicherweise auslöst, vor dem Aufrufer verbergen muss. Wenn nur einige Ausnahmen unterdrückt werden müssen, während andere gemeldet werden müssen, wird der Non-Stop-Modus in der Regel mit einem Aufruf von feupdateenv beendet, nachdem die unerwünschten Ausnahmen gelöscht wurden.
Inhaltsverzeichnis |
Parameter
| envp | - | Zeiger auf das Objekt vom Typ fenv_t , in dem die Gleitkommaumgebung gespeichert wird |
Rückgabewert
0 bei Erfolg, andernfalls ungleich Null.
Beispiel
#include <stdio.h> #include <fenv.h> #include <float.h> #pragma STDC FENV_ACCESS ON void show_fe_exceptions(void) { printf("current exceptions raised: "); if(fetestexcept(FE_DIVBYZERO)) printf(" FE_DIVBYZERO"); if(fetestexcept(FE_INEXACT)) printf(" FE_INEXACT"); if(fetestexcept(FE_INVALID)) printf(" FE_INVALID"); if(fetestexcept(FE_OVERFLOW)) printf(" FE_OVERFLOW"); if(fetestexcept(FE_UNDERFLOW)) printf(" FE_UNDERFLOW"); if(fetestexcept(FE_ALL_EXCEPT)==0) printf(" none"); printf("\n"); } double x2 (double x) /* times two */ { fenv_t curr_excepts; /* Save and clear current f-p environment. */ feholdexcept(&curr_excepts); /* Raise inexact and overflow exceptions. */ printf("In x2(): x = %f\n", x=x*2.0); show_fe_exceptions(); feclearexcept(FE_INEXACT); /* hide inexact exception from caller */ /* Merge caller's exceptions (FE_INVALID) */ /* with remaining x2's exceptions (FE_OVERFLOW). */ feupdateenv(&curr_excepts); return x; } int main(void) { feclearexcept(FE_ALL_EXCEPT); feraiseexcept(FE_INVALID); /* some computation with invalid argument */ show_fe_exceptions(); printf("x2(DBL_MAX) = %f\n", x2(DBL_MAX)); show_fe_exceptions(); return 0; }
Ausgabe:
current exceptions raised: FE_INVALID In x2(): x = inf current exceptions raised: FE_INEXACT FE_OVERFLOW x2(DBL_MAX) = inf current exceptions raised: FE_INVALID FE_OVERFLOW
Referenzen
- C11-Standard (ISO/IEC 9899:2011):
-
- 7.6.4.2 Die feholdexcept-Funktion (S. 213-214)
- C99-Standard (ISO/IEC 9899:1999):
-
- 7.6.4.2 Die feholdexcept-Funktion (S. 194-195)
Siehe auch
|
(C99)
|
stellt die Gleitkommaumgebung wieder her und löst zuvor ausgelöste Ausnahmen aus
(Funktion) |
|
(C99)
|
speichert oder stellt die aktuelle Gleitkommaumgebung wieder her
(Funktion) |
|
(C99)
|
Standard-Gleitkommaumgebung
(Makrokonstante) |
|
C++-Dokumentation
für
feholdexcept
|
|