C ++ feupdateenv () - C ++ Standardbibliothek

Die Funktion feupdateenv () speichert zuerst aktuell ausgelöste Gleitkomma-Ausnahmen, stellt die Gleitkomma-Umgebung aus dem angegebenen fenv_t-Objekt wieder her und löst dann die zuvor gespeicherten Ausnahmen aus.

Die Funktion feupdateenv () ist in der Header-Datei definiert.

feupdateenv () Prototyp

 int feupdateenv (fenv_t * envp);

Die Funktion feupdateenv () verwendet einen Zeiger vom Typ fenv_t als Argument, der eine Gleitkommaumgebung enthält, die zuvor mithilfe von feholdexcept oder fegetenv festgelegt wurde, und diese Gleitkommaumgebung zusammen mit der aktuellen Umgebung wiederherstellt.

feupdateenv () Parameter

  • envp: Zeiger auf das fenv_t-Objekt, das durch einen früheren Aufruf von feholdexcept oder fegetenv festgelegt wurde oder gleich FE_DFL_ENV ist.

feupdateenv () Rückgabewert

  • Bei Erfolg gibt die Funktion feupdateenv () 0 zurück.
  • Bei einem Fehler wird ungleich Null zurückgegeben.

Beispiel: Wie funktioniert die Funktion 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; )

Wenn Sie das Programm ausführen, lautet die Ausgabe wie folgt:

 Ausgelöste Ausnahmen: FE_DIVBYZERO FE_INVALID Ausgelöste Ausnahmen: Keine Ausgelöste Ausnahmen: FE_DIVBYZERO FE_INVALID

Interessante Beiträge...