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

La función feholdexcept () en C ++ primero guarda el entorno de punto flotante actual en un objeto fenv_t y luego borra todos los indicadores de estado de punto flotante.

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

prototipo feholdexcept ()

 int feholdexcept (fenv_t * envp);

La función feholdexcept () guarda el entorno de punto flotante actual en el objeto apuntado por envp como lo hizo fegetenv () y borra todos los indicadores de estado de punto flotante.

Finalmente instala el modo non-stop para que las futuras excepciones de punto flotante no interrumpan la ejecución, hasta que el entorno de punto flotante sea restaurado llamando a feupdateenv o fesetenv.

Parámetros feholdexcept ()

  • envp: puntero a un objeto de tipo fenv_t que almacena el estado del entorno de punto flotante.

feholdexcept () Valor devuelto

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

Ejemplo: ¿Cómo funciona la función feholdexcept ()?

 #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(void) ( fenv_t envp; /* raise certain exceptions */ feraiseexcept(FE_INVALID|FE_DIVBYZERO); print_exceptions(); /* saves and clears current exceptions */ feholdexcept(&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...