Funktionen feclearexcept () i C ++ forsøger at rydde de undtagelsesflag med flydende punkt, der er angivet af argumentet excepts.
Funktionen feclearexcept () er defineret i header-fil.
feclearexcept () Prototype
int feclearexcept (int excepts);
For at funktionen skal fungere, skal du aktivere FENV_ACCESS , som giver dit program adgang til Floating Point-miljøet for at teste de hævede undtagelser.
feclearexcept () Parametre
- excepts: Bitmask-oversigt over undtagelsesflag, der skal slettes
Makro | Type | Beskrivelse |
---|---|---|
FE_DIVBYZERO | Stangfejl | Opdeling med nul |
FE_INEXACT | Inexakt | Ikke nøjagtige resultater såsom (1.0 / 3.0) |
FE_INVALID | Domæne fejl | Mindst et anvendt argument er en værdi, som funktionen ikke er defineret for |
FE_OVERFLOW | Fejl ved overløbsområde | Resultatet er for stort i størrelse til at blive repræsenteret af returtypen |
FE_UNDERFLOW | Fejl i underflowområdet | Resultatet er for lille i størrelse til at blive repræsenteret af returtypen |
FE_ALL_EXCEPT | Alle undtagelser | Alle undtagelser understøttet af implementeringen |
feclearexcept () Returværdi
- Funktionen feclearexcept () returnerer nulværdi, hvis alle undtagelser blev ryddet, eller hvis excepts er lig med nul.
- Det returnerer nul, hvis der opstår en fejl.
Eksempel: Hvordan fungerer feclearexcept ()?
#include #include #include #pragma STDC FENV_ACCESS ON using namespace std; int main() ( // clears all exceptions feclearexcept(FE_ALL_EXCEPT); cout << "1/0 = " << 1.0/0.0 << endl; // tests if above statement raised the FE_DIVBYZERO exception if(fetestexcept(FE_DIVBYZERO)) ( cout << "FE_DIVBYZERO is set" << endl; ) else ( cout << "FE_DIVBYZERO is not set" << endl; ) feclearexcept(FE_ALL_EXCEPT); cout << "sqrt(-1) = " << sqrt(-1) << endl; if(fetestexcept(FE_INVALID)) ( cout << "FE_INVALID is set" << endl; ) else ( cout << "FE_INVALID is not set" << endl; ) )
Når du kører programmet, vil output være:
1/0 = inf FE_DIVBYZERO er indstillet sqrt (-1) = -nan FE_INVALID er indstillet