C ++ feclearexcept () - C ++ standarta bibliotēka

Funkcija feclearexcept () programmā C ++ mēģina notīrīt peldošā komata izņēmuma karodziņus, kurus norādījis arguments.

Funkcija feclearexcept () ir definēta galvenes failā.

feclearexcept () prototips

 int feclearexcept (int izslēdz);

Lai funkcija darbotos, jums jāiespējo FENV_ACCESS , kas jūsu programmai ļaus piekļūt peldošā komata videi, lai pārbaudītu izvirzītos izņēmumus.

feclearexcept () parametri

  • izņēmumi: izdzēst izņēmuma karodziņu saraksts Bitmask
Bitmasks pieņēma makro
Makro Tips Apraksts
FE_DIVBYZERO Pole kļūda Dalīšana ar nulli
FE_INEXACT Neprecīzi Nav precīzi rezultāti, piemēram, (1.0 / 3.0)
FE_INVALID Domēna kļūda Vismaz viens izmantotais arguments ir vērtība, kurai funkcija nav definēta
FE_OVERFLOW Pārplūdes diapazona kļūda Rezultāts ir pārāk liels, lai to attēlotu ar atgriešanās veidu
FE_UNDERFLOW Pārplūdes diapazona kļūda Rezultāts ir pārāk mazs, lai to attēlotu ar atgriešanās veidu
FE_ALL_EXCEPT Visi izņēmumi Visi izņēmumi, kurus atbalsta ieviešana

feclearexcept () Atgriežamā vērtība

  • Funkcija feclearexcept () atgriež nulles vērtību, ja visi izņēmumi ir notīrīti vai ja izņēmumi ir vienādi ar nulli.
  • Ja rodas kāda kļūda, tā atgriež nulli.

Piemērs: Kā darbojas funkcija 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; ) )

Palaidot programmu, izeja būs:

 1/0 = inf FE_DIVBYZERO ir iestatīts sqrt (-1) = -nan FE_INVALID ir iestatīts

Interesanti raksti...