C ++ feupdateenv () - Libreria standard C ++

La funzione feupdateenv () prima salva le eccezioni a virgola mobile attualmente sollevate, ripristina l'ambiente a virgola mobile dall'oggetto fenv_t dato, quindi solleva le eccezioni salvate in precedenza.

La funzione feupdateenv () è definita nel file di intestazione.

prototipo feupdateenv ()

 int feupdateenv (fenv_t * envp);

La funzione feupdateenv () accetta un puntatore di tipo fenv_t come argomento che contiene un ambiente a virgola mobile precedentemente impostato utilizzando feholdexcept o fegetenv e ripristina quell'ambiente a virgola mobile insieme all'ambiente corrente.

parametri feupdateenv ()

  • envp: puntatore all'oggetto fenv_t impostato da una precedente chiamata a feholdexcept o fegetenv o uguale a FE_DFL_ENV.

feupdateenv () Restituisce il valore

  • In caso di successo, la funzione feupdateenv () restituisce 0.
  • In caso di errore, restituisce diverso da zero.

Esempio: come funziona la funzione 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 esegui il programma, l'output sarà:

 Eccezioni sollevate: FE_DIVBYZERO FE_INVALID Eccezioni sollevate: nessuna Eccezioni sollevate: FE_DIVBYZERO FE_INVALID

Articoli interessanti...