feupdateenv() 函數首先保存當前引發的浮點異常,從給定的 fenv_t 對象恢複浮點環境,然後引發先前保存的異常。
feupdateenv() 函數在<cfenv> 頭文件中定義。
feupdateenv()原型
int feupdateenv( fenv_t* envp );
feupdateenv() 函數將 fenv_t 類型的指針作為其參數,該指針保存先前使用 feholdexcept 或 fegetenv 設置的浮點環境,並將該浮點環境與當前環境一起恢複。
參數:
envp
:指向 fenv_t 對象的指針,該對象由先前對 feholdexcept 或 fegetenv 的調用設置或等於 FE_DFL_ENV。
返回:
- 成功時,feupdateenv() 函數返回 0。
- 失敗時,它返回非零。
示例:feupdateenv() 函數如何工作?
#include <iostream>
#include <cmath>
#include <cfenv>
#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;
}
運行程序時,輸出將是:
Raised exceptions: FE_DIVBYZERO FE_INVALID Raised exceptions: None Raised exceptions: FE_DIVBYZERO FE_INVALID
相關用法
- C++ feupdateenv()用法及代碼示例
- C++ fetestexcept()用法及代碼示例
- C++ feof() function用法及代碼示例
- C++ fesetround()用法及代碼示例
- C++ fegetexceptflag()用法及代碼示例
- C++ fesetenv()用法及代碼示例
- C++ feraiseexcept()用法及代碼示例
- C++ fegetenv()用法及代碼示例
- C++ feclearexcept()用法及代碼示例
- 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++ feupdateenv()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。