C ++ feupdateenv () - C ++ Standardbibliotek

Funktionen feupdateenv () sparar först nuvarande undantag för flytande punkter, återställer den flytande punktmiljön från det angivna fenv_t-objektet och höjer sedan de undantag som sparats tidigare.

Funktionen feupdateenv () definieras i rubrikfilen.

feupdateenv () prototyp

 int feupdateenv (fenv_t * envp);

Funktionen feupdateenv () tar en pekare av typen fenv_t som sitt argument som innehåller en flytpunktsmiljö som tidigare ställts in med feholdexcept eller fegetenv och återställer den flytpunktsmiljön tillsammans med den aktuella miljön.

feupdateenv () Parametrar

  • envp: Pekare till fenv_t-objektet som ställts in av ett tidigare anrop till feholdexcept eller fegetenv eller är lika med FE_DFL_ENV.

feupdateenv () Returvärde

  • Efter framgång returnerar funktionen feupdateenv () 0.
  • Vid fel returnerar den noll.

Exempel: Hur fungerar feupdateenv () -funktionen?

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

När du kör programmet blir resultatet:

 Upphöjda undantag: FE_DIVBYZERO FE_INVALID Upphöjda undantag: Inga Upphöjda undantag: FE_DIVBYZERO FE_INVALID

Intressanta artiklar...