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) 尝试将列于excepts的浮点异常标志的完整内容,从*flagp复制到浮点环境。不会引发任何异常,只修改标志。

浮点异常标志的完整内容不必是一个指示异常被引发或清除的布尔值。譬如,它可以是一个包含布尔状态和引起异常的代码地址的结构体。这些函数获取所有这种内容,并将其存储于/读取自*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)

[编辑] 参阅

fegetexceptflagfesetexceptflagC++文档