C ++ feupdateenv () - štandardná knižnica C ++

Funkcia feupdateenv () najskôr uloží aktuálne zdvihnuté výnimky s pohyblivou rádovou čiarkou, obnoví prostredie s pohyblivou rádovou čiarkou z daného objektu fenv_t, potom vyvolá predtým uložené výnimky.

Funkcia feupdateenv () je definovaná v hlavičkovom súbore.

prototyp feupdateenv ()

 int feupdateenv (fenv_t * envp);

Funkcia feupdateenv () berie ako argument ukazovateľ typu fenv_t, ktorý obsahuje prostredie s pohyblivou rádovou čiarkou predtým nastavené pomocou feholdexcept alebo fegetenv a obnovuje toto prostredie s pohyblivou rádovou čiarkou spolu s aktuálnym prostredím.

parametre feupdateenv ()

  • envp: Ukazovateľ na objekt fenv_t, ktorý je nastavený predchádzajúcim volaním feholdexcept alebo fegetenv alebo sa rovná FE_DFL_ENV.

feupdateenv () Vrátená hodnota

  • Pri úspechu funkcia feupdateenv () vráti 0.
  • Pri zlyhaní vráti nenulovú hodnotu.

Príklad: Ako funguje funkcia 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; )

Po spustení programu bude výstup:

 Zvýšené výnimky: FE_DIVBYZERO FE_INVALID Zvýšené výnimky: Žiadne Zvýšené výnimky: FE_DIVBYZERO FE_INVALID

Zaujímavé články...