C ++ feupdateenv () - Standardna knjižnica C ++

Funkcija feupdateenv () prvo sprema trenutno podignute iznimke s pomičnom zarezom, vraća okruženje s pomičnom zarezom iz datog objekta fenv_t, a zatim podiže prethodno spremljene iznimke.

Funkcija feupdateenv () definirana je u datoteci zaglavlja.

prototip feupdateenv ()

 int feupdateenv (fenv_t * envp);

Funkcija feupdateenv () za svoj argument uzima pokazivač tipa fenv_t koji sadrži okruženje s pomičnom zarezom prethodno postavljeno pomoću feholdexcept ili fegetenv i obnavlja to okruženje s pomičnim zarezom zajedno s trenutnim okruženjem.

parametri feupdateenv ()

  • envp: Pokazivač na fenv_t objekt koji je postavljen ranijim pozivom na feholdexcept ili fegetenv ili je jednak FE_DFL_ENV.

feupdateenv () Povratna vrijednost

  • Nakon uspjeha funkcija feupdateenv () vraća 0.
  • U slučaju neuspjeha, vraća se nula.

Primjer: Kako funkcionira funkcija feupdateenv ()?

 #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() ( fenv_t envp; /* raise certain exceptions */ feraiseexcept(FE_INVALID|FE_DIVBYZERO); print_exceptions(); /* saves and clears current exceptions */ feupdateenv(&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

Zanimljivi članci...