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

A função feclearexcept () em C ++ tenta limpar os sinalizadores de exceção de ponto flutuante especificados pelas exceções de argumento.

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

feclearexcept () Protótipo

 int feclearexcept (int exceções);

Para que a função funcione, você deve habilitar FENV_ACCESS , o que dará ao seu programa acesso ao ambiente de ponto flutuante para testar as exceções levantadas.

feclearexcept () Parâmetros

  • exceções: lista de bitmask de sinalizadores de exceção para limpar
Macros de bitmask aceitos
Macro Tipo Descrição
FE_DIVBYZERO Erro de pólo Divisão por zero
FE_INEXACT Inexato Resultados não exatos, como (1.0 / 3.0)
FE_INVALID Erro de domínio Pelo menos um dos argumentos usados ​​é um valor para o qual a função não está definida
FE_OVERFLOW Erro de faixa de estouro O resultado é muito grande em magnitude para ser representado pelo tipo de retorno
FE_UNDERFLOW Erro de faixa de underflow O resultado é muito pequeno em magnitude para ser representado pelo tipo de retorno
FE_ALL_EXCEPT Todas as exceções Todas as exceções suportadas pela implementação

feclearexcept () Valor de retorno

  • A função feclearexcept () retorna valor zero se todas as exceções foram apagadas ou se exceções for igual a zero.
  • Ele retorna diferente de zero se ocorrer algum erro.

Exemplo: Como funciona a função feclearexcept ()?

 #include #include #include #pragma STDC FENV_ACCESS ON using namespace std; int main() ( // clears all exceptions feclearexcept(FE_ALL_EXCEPT); cout << "1/0 = " << 1.0/0.0 << endl; // tests if above statement raised the FE_DIVBYZERO exception if(fetestexcept(FE_DIVBYZERO)) ( cout << "FE_DIVBYZERO is set" << endl; ) else ( cout << "FE_DIVBYZERO is not set" << endl; ) feclearexcept(FE_ALL_EXCEPT); cout << "sqrt(-1) = " << sqrt(-1) << endl; if(fetestexcept(FE_INVALID)) ( cout << "FE_INVALID is set" << endl; ) else ( cout << "FE_INVALID is not set" << endl; ) )

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

 1/0 = inf FE_DIVBYZERO está definido sqrt (-1) = -nan FE_INVALID está definido

Artigos interessantes...