Fungsi feupdateenv () pertama kali menyimpan pengecualian titik terapung yang dinaikkan, memulihkan persekitaran titik terapung dari objek fenv_t yang diberikan, kemudian menaikkan pengecualian yang disimpan sebelumnya.
Fungsi feupdateenv () ditentukan dalam fail header.
prototaip feupdateenv ()
int feupdateenv (fenv_t * envp);
Fungsi feupdateenv () mengambil penunjuk jenis fenv_t sebagai argumennya yang memegang persekitaran titik terapung yang sebelumnya ditetapkan dengan menggunakan feholdexcept atau fegetenv dan mengembalikan persekitaran titik terapung itu bersama dengan persekitaran semasa.
Feupdateenv () Parameter
- envp: Penunjuk ke objek fenv_t yang ditetapkan oleh panggilan sebelumnya ke feholdexcept atau fegetenv atau sama dengan FE_DFL_ENV.
feupdateenv () Nilai pulangan
- Pada kejayaan, fungsi feupdateenv () mengembalikan 0.
- Sekiranya gagal, ia mengembalikan bukan sifar.
Contoh: Bagaimana fungsi feupdateenv () berfungsi?
#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; )
Semasa anda menjalankan program, outputnya adalah:
Pengecualian yang dinaikkan: FE_DIVBYZERO FE_INVALID Pengecualian yang meningkat: Tiada Pengecualian yang dinaikkan: FE_DIVBYZERO FE_INVALID