C ++: n funktio feclearexcept () yrittää tyhjentää argumenttien poissulkemien liukulukuisten poikkeusten liput.
Feclearexcept () -funktio määritetään otsikkotiedostossa.
feclearexcept () Prototyyppi
int feclearexcept (int poissulkee);
Jotta toiminto toimisi, sinun on otettava käyttöön FENV_ACCESS , joka antaa ohjelmallesi pääsyn liukulukuympäristöön testatakseen esiin tuotuja poikkeuksia.
feclearexcept () -parametrit
- poikkeukset: Bitmask-luettelo tyhjennettävistä poikkeuslipuista
Makro | Tyyppi | Kuvaus |
---|---|---|
FE_DIVBYZERO | Napavirhe | Nollalla jakaminen |
FE_INEXACT | Epätarkka | Ei tarkat tulokset, kuten (1.0 / 3.0) |
FE_INVALID | Verkkotunnuksen virhe | Ainakin yksi käytetty argumentti on arvo, jolle toimintoa ei ole määritelty |
FE_OVERFLOW | Ylivuotoalueen virhe | Tulos on liian suuri, jotta sitä voidaan esittää paluutyypillä |
FE_UNDERFLOW | Alivirtausalueen virhe | Tulos on liian pieni, jotta sitä voidaan esittää paluutyypillä |
FE_ALL_EXCEPT | Kaikki poikkeukset | Kaikki toteutuksen tukemat poikkeukset |
feclearexcept () Palautusarvo
- Funktio feclearexcept () palauttaa arvon nolla, jos kaikki poikkeukset on tyhjennetty tai jos poikkeukset ovat yhtä suuria kuin nolla.
- Se palauttaa nollan, jos ilmenee virheitä.
Esimerkki: Kuinka funktio feclearexcept () toimii?
#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; ) )
Kun suoritat ohjelmaa, tulos on:
1/0 = inf FE_DIVBYZERO on asetettu sqrt (-1) = -nan FE_INVALID on asetettu