C ++ feupdateenv () - Biblioteca estándar de C ++

La función feupdateenv () primero guarda las excepciones de punto flotante actualmente generadas, restaura el entorno de punto flotante del objeto fenv_t dado y luego genera las excepciones guardadas previamente.

La función feupdateenv () se define en el archivo de encabezado.

prototipo feupdateenv ()

 int feupdateenv (fenv_t * envp);

La función feupdateenv () toma un puntero de tipo fenv_t como argumento que contiene un entorno de punto flotante previamente establecido mediante feholdexcept o fegetenv y restaura ese entorno de punto flotante junto con el entorno actual.

Parámetros de feupdateenv ()

  • envp: puntero al objeto fenv_t establecido por una llamada anterior a feholdexcept o fegetenv o que es igual a FE_DFL_ENV.

feupdateenv () Valor de retorno

  • En caso de éxito, la función feupdateenv () devuelve 0.
  • Si falla, devuelve un valor distinto de cero.

Ejemplo: ¿Cómo funciona la función 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; )

Cuando ejecute el programa, la salida será:

 Excepciones planteadas: FE_DIVBYZERO FE_INVALID Excepciones planteadas: Ninguna Excepciones planteadas: FE_DIVBYZERO FE_INVALID

Articulos interesantes...