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

Funkcija feupdateenv () vispirms saglabā pašreiz izvirzītos peldošā komata izņēmumus, atjauno peldošā komata vidi no norādītā objekta fenv_t, pēc tam paaugstina iepriekš saglabātos izņēmumus.

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

feupdateenv () prototips

 int feupdateenv (fenv_t * envp);

Funkcija feupdateenv () par argumentu ņem fenv_t tipa rādītāju, kas satur peldošā komata vidi, kas iepriekš iestatīta, izmantojot feholdexcept vai fegetenv, un atjauno šo peldošā komata vidi kopā ar pašreizējo vidi.

feupdateenv () parametri

  • envp: objekta fenv_t rādītājs, kuru iestatījis iepriekšējs zvans uz feholdexcept vai fegetenv vai kas ir vienāds ar FE_DFL_ENV.

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

  • Pēc panākumiem funkcija feupdateenv () atgriež 0.
  • Pēc neveiksmes tas atgriež nulli.

Piemērs: Kā darbojas feupdateenv () funkcija?

 #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; )

Palaidot programmu, izeja būs:

 Paaugstinātie izņēmumi: FE_DIVBYZERO FE_INVALID Paaugstinātie izņēmumi: Nav Paaugstinātie izņēmumi: FE_DIVBYZERO FE_INVALID

Interesanti raksti...