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()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。