C ++ feupdateenv () - Стандартна бібліотека C ++

Функція feupdateenv () спочатку зберігає підняті на даний момент винятки з плаваючою комою, відновлює середовище з плаваючою точкою з даного об'єкта fenv_t, потім піднімає винятки, збережені раніше.

Функція feupdateenv () визначена у файлі заголовка.

feupdateenv () прототип

 int feupdateenv (fenv_t * envp);

Функція feupdateenv () приймає в якості аргументу покажчик типу fenv_t, який містить середовище з плаваючою комою, встановлене раніше за допомогою feholdexcept або fegetenv, і відновлює це середовище з плаваючою точкою разом із поточним середовищем.

feupdateenv () Параметри

  • envp: Вказівник на об'єкт fenv_t, який встановлено попереднім викликом feholdexcept або fegetenv або дорівнює FE_DFL_ENV.

feupdateenv () Повернене значення

  • Після успіху функція feupdateenv () повертає 0.
  • У разі відмови він повертає ненульове значення.

Приклад: Як працює функція 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; )

Коли ви запускаєте програму, результат буде:

 Збільшені винятки: FE_DIVBYZERO FE_INVALID Збільшені винятки: Немає Збільшені винятки: FE_DIVBYZERO FE_INVALID

Цікаві статті...