C ++ feupdateenv () - biblioteka standardowa C ++

Funkcja feupdateenv () najpierw zapisuje aktualnie zgłoszone wyjątki zmiennoprzecinkowe, przywraca środowisko zmiennoprzecinkowe z podanego obiektu fenv_t, a następnie podnosi wyjątki zapisane wcześniej.

Funkcja feupdateenv () jest zdefiniowana w pliku nagłówkowym.

prototyp feupdateenv ()

 int feupdateenv (fenv_t * envp);

Funkcja feupdateenv () przyjmuje jako argument wskaźnik typu fenv_t, który przechowuje środowisko zmiennoprzecinkowe ustawione wcześniej przy użyciu funkcji feholdexcept lub fegetenv i przywraca to środowisko zmiennoprzecinkowe wraz z bieżącym środowiskiem.

feupdateenv () Parametry

  • envp: Wskaźnik do obiektu fenv_t, który jest ustawiany przez wcześniejsze wywołanie feholdexcept lub fegetenv lub jest równy FE_DFL_ENV.

feupdateenv () Wartość zwracana

  • Po pomyślnym zakończeniu funkcja feupdateenv () zwraca 0.
  • W przypadku niepowodzenia zwraca wartość różną od zera.

Przykład: Jak działa funkcja 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 uruchomieniu programu wynik będzie następujący:

 Zgłoszone wyjątki: FE_DIVBYZERO FE_INVALID Zgłoszone wyjątki: Brak Zgłoszone wyjątki: FE_DIVBYZERO FE_INVALID

Interesujące artykuły...