Функція feclearexcept () у C ++ намагається очистити прапорці винятків з плаваючою комою, визначені аргументом excepts.
Функція feclearexcept () визначена у файлі заголовка.
feclearexcept () Прототип
int feclearexcept (int excepts);
Щоб функція працювала, слід увімкнути FENV_ACCESS , який надасть вашій програмі доступ до середовища з плаваючою комою для перевірки винятків.
feclearexcept () Параметри
- винятки: Бітмаска з переліком прапорів винятків для очищення
Макрос | Тип | Опис |
---|---|---|
FE_DIVBYZERO | Помилка полюса | Ділення на нуль |
FE_INEXACT | Неточний | Неточні результати, такі як (1.0 / 3.0) |
FE_INVALID | Помилка домену | Принаймні один аргумент, що використовується, є значенням, для якого функція не визначена |
FE_OVERFLOW | Помилка діапазону переповнення | Результат занадто великий за величиною, щоб бути представленим типом повернення |
FE_UNDERFLOW | Помилка діапазону недотоку води | Результат занадто малий за величиною, щоб бути представленим типом повернення |
FE_ALL_EXCEPT | Усі винятки | Всі винятки, підтримані реалізацією |
feclearexcept () Повертається значення
- Функція feclearexcept () повертає нульове значення, якщо всі виключення були очищені або якщо excepts дорівнює нулю.
- Він повертає ненульове значення, якщо виникає помилка.
Приклад: Як працює функція 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; ) )
Коли ви запускаєте програму, результат буде:
1/0 = inf FE_DIVBYZERO встановлено sqrt (-1) = -nan FE_INVALID встановлено