A feupdateenv () függvény először elmenti az aktuálisan felvetett lebegőpontos kivételeket, visszaállítja a lebegőpontos környezetet az adott fenv_t objektumból, majd felveti a korábban mentett kivételeket.
A feupdateenv () függvény a fejlécfájlban van meghatározva.
feupdateenv () prototípus
int feupdateenv (fenv_t * envp);
A feupdateenv () függvény argumentumként a fenv_t típusú mutatót veszi fel, amely egy lebegőpontos környezetet tartalmaz, amelyet korábban a feholdexcept vagy a fegetenv használatával állítottak be, és helyreállítja ezt a lebegőpontos környezetet az aktuális környezettel együtt.
feupdateenv () Paraméterek
- envp: A fenv_t objektum mutatója, amelyet egy korábbi feholdexcept vagy fegetenv hívás állított be, vagy egyenlő FE_DFL_ENV.
feupdateenv () Visszatérési érték
- Siker esetén a feupdateenv () függvény 0-t ad vissza.
- Meghibásodás esetén nem nullát ad vissza.
Példa: Hogyan működik a feupdateenv () függvény?
#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; )
A program futtatásakor a kimenet a következő lesz:
Felemelt kivételek: FE_DIVBYZERO FE_INVALID Felemelt kivételek: Nincsenek Felemelt kivételek: FE_DIVBYZERO FE_INVALID