C ++ feupdateenv () - C ++ standaardbibliotheek

De functie feupdateenv () slaat eerst de momenteel verhoogde floating-point-uitzonderingen op, herstelt de floating-point-omgeving van het opgegeven fenv_t-object en verhoogt vervolgens de eerder opgeslagen uitzonderingen.

De functie feupdateenv () is gedefinieerd in het header-bestand.

feupdateenv () prototype

 int feupdateenv (fenv_t * envp);

De functie feupdateenv () neemt een pointer van het type fenv_t als argument die een drijvende-komma-omgeving bevat die eerder is ingesteld met feholdexcept of fegetenv, en herstelt die drijvende-komma-omgeving samen met de huidige omgeving.

feupdateenv () Parameters

  • envp: Pointer naar het fenv_t-object dat is ingesteld door een eerdere aanroep van feholdexcept of fegetenv of gelijk is aan FE_DFL_ENV.

feupdateenv () Retourwaarde

  • Bij succes retourneert de functie feupdateenv () 0.
  • Bij een fout wordt niet-nul geretourneerd.

Voorbeeld: hoe werkt de feupdateenv () -functie?

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

Wanneer u het programma uitvoert, is de uitvoer:

 Verhoogde uitzonderingen: FE_DIVBYZERO FE_INVALID Verhoogde uitzonderingen: geen Verhoogde uitzonderingen: FE_DIVBYZERO FE_INVALID

Interessante artikelen...