C ++ feupdateenv () - Biblioteca C ++ Padrão

A função feupdateenv () primeiro salva as exceções de ponto flutuante levantadas no momento, restaura o ambiente de ponto flutuante do objeto fenv_t fornecido e, em seguida, levanta as exceções salvas anteriormente.

A função feupdateenv () é definida no arquivo de cabeçalho.

protótipo feupdateenv ()

 int feupdateenv (fenv_t * envp);

A função feupdateenv () leva um ponteiro do tipo fenv_t como seu argumento, o qual mantém um ambiente de ponto flutuante previamente definido usando feholdexcept ou fegetenv e restaura esse ambiente de ponto flutuante junto com o ambiente atual.

Parâmetros feupdateenv ()

  • envp: Ponteiro para o objeto fenv_t que é definido por uma chamada anterior para feholdexcept ou fegetenv ou é igual a FE_DFL_ENV.

feupdateenv () Valor de retorno

  • Em caso de sucesso, a função feupdateenv () retorna 0.
  • Em caso de falha, ele retorna diferente de zero.

Exemplo: Como funciona a função 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; )

Quando você executa o programa, a saída será:

 Exceções levantadas: FE_DIVBYZERO FE_INVALID Exceções levantadas: Nenhuma Exceções levantadas: FE_DIVBYZERO FE_INVALID

Artigos interessantes...