fegetexceptflag, fesetexceptflag

来自cppreference.com
< c‎ | numeric‎ | fenv
定义于头文件 <fenv.h>
int fegetexceptflag( fexcept_t* flagp, int excepts );
(1) (C99 起)
int fesetexceptflag( const fexcept_t* flagp, int excepts );
(2) (C99 起)

1) 试图获得列于位掩码参数 excepts 的浮点异常标志的完整内容,它是浮点异常宏的逐位或。

2) 试图从 flagp 复制列于 excepts 的浮点异常标志到浮点环境。不引发任何异常,只修改标志。

浮点异常标志的完整内容不必是指示是否引发或清除异常的布尔值。例如,它可以是结构体,包含布尔状态和触发了异常的代码地址。这些函数获得所有这种内容,并以实现定义格式于 flagp 获得/存储它。

参数

flagp - 指向将要存储或读取标志位置的 fexcept_t 对象的指针
excepts - 列出要获取/设置的异常的位掩码

返回值

成功时返回 0 ,否则返回非零。

示例

#include <stdio.h>
#include <fenv.h>
 
#pragma STDC FENV_ACCESS ON
 
void show_fe_exceptions(void)
{
    printf("current exceptions raised: ");
    if(fetestexcept(FE_DIVBYZERO))     printf(" FE_DIVBYZERO");
    if(fetestexcept(FE_INEXACT))       printf(" FE_INEXACT");
    if(fetestexcept(FE_INVALID))       printf(" FE_INVALID");
    if(fetestexcept(FE_OVERFLOW))      printf(" FE_OVERFLOW");
    if(fetestexcept(FE_UNDERFLOW))     printf(" FE_UNDERFLOW");
    if(fetestexcept(FE_ALL_EXCEPT)==0) printf(" none");
    printf("\n");
}
 
int main(void)
{
    fexcept_t excepts;
 
    /* 设置“当前”异常标志集合。 */
    feraiseexcept(FE_INVALID);
    show_fe_exceptions();
 
    /* 保存当前异常标志。 */
    fegetexceptflag(&excepts,FE_ALL_EXCEPT);
 
    /* 临时引发二个其他异常。 */
    feclearexcept(FE_ALL_EXCEPT);
    feraiseexcept(FE_OVERFLOW | FE_INEXACT);
    show_fe_exceptions();
 
    /* 恢复先前的异常标志。 */
    fesetexceptflag(&excepts,FE_ALL_EXCEPT);
    show_fe_exceptions();
 
    return 0;
}

输出:

current exceptions raised: FE_INVALID
current exceptions raised: FE_INEXACT FE_OVERFLOW
current exceptions raised: FE_INVALID

引用

  • C11 standard (ISO/IEC 9899:2011):
  • 7.6.2.2 The fegetexceptflag function (p: 210)
  • 7.6.2.4 The fesetexceptflag function (p: 211)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.6.2.2 The fegetexceptflag function (p: 191)
  • 7.6.2.4 The fesetexceptflag function (p: 192)

参阅