feupdateenv
函数 <cfenv>
int feupdateenv (const fenv_t* envp);
更新浮点环境
建立由envp所指向的对象所表示的浮点环境状态。然后,触发在调用之前在浮点环境中设置的异常。
调用此函数的程序应确保为调用启用了编译标志
FENV_ACCESS。
☲ 参数
envp
一个指向fenv_t值的指针(由之前调用fegetenv或feholdexcept设置),或者一个浮点环境宏值:
某些库实现可能支持附加的浮点环境状态值(其对应的宏也以FE_开头)。
☉ 返回值
如果函数成功完成,则为0。
否则为非零值。
☣ 示例
/* feholdexcept/feupdateenv example */
#include <stdio.h> /* printf, puts */
#include <fenv.h> /* feholdexcept, feclearexcept, fetestexcept, feupdateenv, FE_* */
#include <math.h> /* log */
#pragma STDC FENV_ACCESS on
double log_zerook (double x) {
fenv_t fe;
feholdexcept(&fe);
x=log(x);
feclearexcept (FE_OVERFLOW|FE_DIVBYZERO);
feupdateenv(&fe);
return x;
}
int main ()
{
feclearexcept (FE_ALL_EXCEPT);
printf ("log(0.0): %f\n", log_zerook(0.0));
if (!fetestexcept(FE_ALL_EXCEPT))
puts ("no exceptions raised");
return 0;
}
|
可能输出:
log(0.0): -inf
no exceptions raised
↭ 数据竞争
每个线程使用自己的状态维护一个单独的浮点环境。如果生成一个新线程就复制当前状态。[这适用于C11和c++ 11实现]
➤ 异常
无抛出保证:此函数不会抛出异常。
注意,C浮点异常不是c++异常,因此不会被try/catch块捕获。
🍄 另请参阅