feupdateenv
From cppreference.net
|
Definido en el encabezado
<fenv.h>
|
||
|
int
feupdateenv
(
const
fenv_t
*
envp
)
;
|
(desde C99) | |
Primero, recuerda las excepciones de punto flotante actualmente activadas, luego restaura el entorno de punto flotante desde el objeto apuntado por
envp
(similar a
fesetenv
), luego activa las excepciones de punto flotante que fueron guardadas.
Esta función puede utilizarse para finalizar el modo no-stop establecido por una llamada anterior a feholdexcept .
Contenidos |
Parámetros
| envp | - |
puntero al objeto de tipo
fenv_t
establecido por una llamada anterior a
feholdexcept
o
fegetenv
o igual a
FE_DFL_ENV
|
Valor de retorno
0 en caso de éxito, distinto de cero en caso contrario.
Ejemplo
Ejecutar este código
#include <stdio.h> #include <fenv.h> #include <float.h> #pragma STDC FENV_ACCESS ON void show_fe_exceptions(void) { printf("current exceptions raised: "); if(fetestexcept(FE_DIVBYZERO)) printf(" FE_DIVBYZERO"); if(fetestexcept(FE_INEXACT)) printf(" FE_INEXACT"); if(fetestexcept(FE_INVALID)) printf(" FE_INVALID"); if(fetestexcept(FE_OVERFLOW)) printf(" FE_OVERFLOW"); if(fetestexcept(FE_UNDERFLOW)) printf(" FE_UNDERFLOW"); if(fetestexcept(FE_ALL_EXCEPT)==0) printf(" none"); printf("\n"); } double x2 (double x) /* times two */ { fenv_t curr_excepts; /* Save and clear current f-p environment. */ feholdexcept(&curr_excepts); /* Raise inexact and overflow exceptions. */ printf("In x2(): x = %f\n", x=x*2.0); show_fe_exceptions(); feclearexcept(FE_INEXACT); /* hide inexact exception from caller */ /* Merge caller's exceptions (FE_INVALID) */ /* with remaining x2's exceptions (FE_OVERFLOW). */ feupdateenv(&curr_excepts); return x; } int main(void) { feclearexcept(FE_ALL_EXCEPT); feraiseexcept(FE_INVALID); /* some computation with invalid argument */ show_fe_exceptions(); printf("x2(DBL_MAX) = %f\n", x2(DBL_MAX)); show_fe_exceptions(); return 0; }
Salida:
current exceptions raised: FE_INVALID In x2(): x = inf current exceptions raised: FE_INEXACT FE_OVERFLOW x2(DBL_MAX) = inf current exceptions raised: FE_INVALID FE_OVERFLOW
Referencias
- Estándar C11 (ISO/IEC 9899:2011):
-
- 7.6.4.4 La función feupdateenv (p: 214-215)
- Estándar C99 (ISO/IEC 9899:1999):
-
- 7.6.4.4 La función feupdateenv (p: 195-196)
Véase también
|
(C99)
|
guarda el entorno, limpia todos los flags de estado e ignora todos los errores futuros
(función) |
|
(C99)
|
guarda o restaura el entorno actual de punto flotante
(función) |
|
(C99)
|
entorno predeterminado de punto flotante
(constante macro) |
|
Documentación de C++
para
feupdateenv
|
|