C++ 中的feclearexcept() 函數嘗試清除由參數 excepts 指定的浮點異常標誌。
feclearexcept() 函數在<cfenv> 頭文件中定義。
feclearexcept() 原型
int feclearexcept(int excepts);
要使該函數正常工作,您應該啟用FENV_ACCESS,這將使您的程序能夠訪問浮點環境以測試引發的異常。
參數:
excepts
:要清除的異常標誌的位掩碼列表
宏 | 類型 | 說明 |
---|---|---|
FE_DIVBYZERO | 極差 | 被零除 |
FE_INEXACT | Inexact | 不準確的結果,例如 (1.0/3.0) |
FE_INVALID | 域錯誤 | 使用的至少一個參數是未定義函數的值 |
FE_OVERFLOW | 溢出範圍錯誤 | 結果量級太大,無法用返回類型表示 |
FE_UNDERFLOW | 下溢範圍錯誤 | 結果量級太小,無法用返回類型表示 |
FE_ALL_EXCEPT | 所有例外 | 實現支持的所有異常 |
返回:
- feclearexcept() 函數返回零值,如果所有異常都被清除或者excepts 等於零。
- 如果發生任何錯誤,它會返回非零值。
示例:feclearexcept() 函數如何工作?
#include <iostream>
#include <cfenv>
#include <cmath>
#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 is set sqrt(-1) = -nan FE_INVALID is set
相關用法
- C++ fetestexcept()用法及代碼示例
- C++ feupdateenv()用法及代碼示例
- C++ feof() function用法及代碼示例
- C++ fesetround()用法及代碼示例
- C++ fegetexceptflag()用法及代碼示例
- C++ fesetenv()用法及代碼示例
- C++ feraiseexcept()用法及代碼示例
- C++ fegetenv()用法及代碼示例
- C++ fesetexceptflag()用法及代碼示例
- C++ feholdexcept()用法及代碼示例
- C++ ferror()用法及代碼示例
- C++ fegetround()用法及代碼示例
- C++ fcvt()用法及代碼示例
- C++ fwscanf()用法及代碼示例
- C++ fmax()用法及代碼示例
- C++ fdim()用法及代碼示例
- C++ fmin()用法及代碼示例
- C++ forward_list::unique()用法及代碼示例
- C++ forward_list::emplace_front()用法及代碼示例
- C++ fopen()用法及代碼示例
注:本文由純淨天空篩選整理自 C++ feclearexcept()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。