C ++ feholdexcept () - C ++ standartinė biblioteka

Funkcija feholdexcept () C ++ pirmiausia išsaugo esamą slankiojo kablelio aplinką objekte fenv_t ir tada išvalo visas slankiojo kablelio būsenos žymes.

Funkcija feholdexcept () yra apibrėžta antraštės faile.

feholdexcept () prototipas

 int feholdexcept (fenv_t * envp);

Funkcija feholdexcept () išsaugo esamą slankiojo kablelio aplinką objekte, kurį nurodo envp, kaip tai daro fegetenv (), ir išvalo visas slankiojo kablelio būsenos vėliavas.

Galiausiai jis įdiegia „non-stop“ režimą, kad būsimos slankiojo kablelio išimtys nenutrauktų vykdymo, kol slankiojo kablelio aplinka nebus atkurta paskambinus feupdateenv arba fesetenv.

feholdexcept () parametrai

  • envp: Fenv_t tipo objekto žymeklis, kuriame saugoma slankiojo kablelio aplinkos būsena.

feholdexcept () Grąžinimo vertė

  • Sėkmės atveju funkcija feholdexcept () grąžina 0.
  • Po nesėkmės jis pateikia nulį.

Pavyzdys: Kaip veikia funkcija feholdexcept ()?

 #include #include #include #pragma STDC FENV_ACCESS ON using namespace std; void print_exceptions() ( cout << "Raised exceptions: "; if(fetestexcept(FE_ALL_EXCEPT)) ( if(fetestexcept(FE_DIVBYZERO)) cout << "FE_DIVBYZERO "; if(fetestexcept(FE_INEXACT)) cout << "FE_INEXACT "; if(fetestexcept(FE_INVALID)) cout << "FE_INVALID "; if(fetestexcept(FE_OVERFLOW)) cout << "FE_OVERFLOW "; if(fetestexcept(FE_UNDERFLOW)) cout << "FE_UNDERFLOW "; ) else cout << "None"; cout << endl; ) int main(void) ( fenv_t envp; /* raise certain exceptions */ feraiseexcept(FE_INVALID|FE_DIVBYZERO); print_exceptions(); /* saves and clears current exceptions */ feholdexcept(&envp); print_exceptions(); /* restores saved exceptions */ feupdateenv(&envp); print_exceptions(); return 0; )

Kai paleisite programą, išvestis bus:

 Iškeltos išimtys: FE_DIVBYZERO FE_INVALID Iškeltos išimtys: Nėra Paaukštintos išimtys: FE_DIVBYZERO FE_INVALID

Įdomios straipsniai...