A função feholdexcept () em C ++ primeiro salva o ambiente de ponto flutuante atual em um objeto fenv_t e depois limpa todos os sinalizadores de status de ponto flutuante.
A função feholdexcept () é definida no arquivo de cabeçalho.
protótipo feholdexcept ()
int feholdexcept (fenv_t * envp);
A função feholdexcept () salva o ambiente de ponto flutuante atual no objeto apontado por envp como feito por fegetenv () e limpa todos os sinalizadores de status de ponto flutuante.
Finalmente, ele instala o modo non-stop para que as futuras exceções de ponto flutuante não interrompam a execução, até que o ambiente de ponto flutuante seja restaurado chamando feupdateenv ou fesetenv.
Parâmetros feholdexcept ()
- envp: Ponteiro para um objeto do tipo fenv_t que armazena o status do ambiente de ponto flutuante.
feholdexcept () Valor de retorno
- Em caso de sucesso, a função feholdexcept () retorna 0.
- Em caso de falha, ele retorna diferente de zero.
Exemplo: Como funciona a função 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; )
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