Funkcija feholdexcept () u C ++ prvo sprema trenutačno okruženje s pomičnom zarezom u objekt fenv_t, a zatim briše sve zastavice statusa s pomičnim zarezom.
Funkcija feholdexcept () definirana je u datoteci zaglavlja.
prototip feholdexcept ()
int feholdexcept (fenv_t * envp);
Funkcija feholdexcept () sprema trenutačno okruženje s pomičnom zarezom na objekt ukazan envp kao što je to učinio fegetenv () i briše sve zastavice statusa plivajuće točke.
Konačno, instalira non-stop način tako da buduće iznimke s pomičnom zarezom neće ometati izvršavanje, sve dok se okruženje s pomičnom zarezom ne obnovi pozivanjem feupdateenv ili fesetenv.
feholdexcept () Parametri
- envp: Pokazivač na objekt tipa fenv_t koji pohranjuje status okoline s pomičnom zarezom.
feholdexcept () Povratna vrijednost
- U uspjehu, funkcija feholdexcept () vraća 0.
- U slučaju neuspjeha, vraća se nula.
Primjer: Kako funkcionira 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; )
Kada pokrenete program, izlaz će biti:
Povećane iznimke: FE_DIVBYZERO FE_INVALID Povećane iznimke: Nema Povećane iznimke: FE_DIVBYZERO FE_INVALID