1

我想在 Windows 上处理 fpu 异常,例如:

#include <math.h>
#include <fenv.h>
#include <stdio.h>

int main()
{
    double b = 0;
    int raised;
    feclearexcept (FE_ALL_EXCEPT);
    b /= 0;
    raised = fetestexcept (FE_OVERFLOW | FE_INVALID);
    if (raised & FE_OVERFLOW) { printf("over\n");}
    if (raised & FE_INVALID)  { printf("invalid\n");}

    return 0;
}

但是在窗户上。我尝试阅读 MSDN,但文件根本不清楚。我想在 x86 和 amd64 架构上使用 Visual Studio 编译器来做到这一点。

我对在 C++ 中翻译异常不感兴趣——实际上,我什至对 FPU 异常都不感兴趣,只对经过一些计算后知道 FPU 状态感兴趣,就像上面的例子一样。

== 编辑 ==

好的,看起来它实际上要简单得多:使用 _clearfp 就足够了:

#include <math.h>
#include <float.h>
#include <stdio.h>

int main()
{
    double b = 0;
    int raised;
    raised = _clearfp();
    b /= 0;
    raised = _clearfp();
    if (raised & SW_INVALID)  { printf("invalid\n");}

    return 0;
}

比处理异常、SEH 和其他不可移植的东西要好得多:)

4

3 回答 3

2

如果是 Visual Studio,请尝试输入以下行:

#pragma   float_control (except, on)

更多关于这里这里的信息。

编辑:

如果您想在纯 C 中执行此操作,则需要查看结构化异常处理 ( SEH )。

于 2009-02-22T13:07:09.010 回答
2

您可以使用 _statusfp2() 检索浮点状态。注意 32 位同时使用 FPU 和 SSE 指令。一些示例代码:

#include "stdafx.h"
#include <float.h>
#include <math.h>
#include <assert.h>


int _tmain(int argc, _TCHAR* argv[])
{
  unsigned x86;
  unsigned sse;
  // Test zero-divide
  double d = 0;
  double v = 1 / d;
  _statusfp2(&x86, &sse);
  assert(x86 & _EM_ZERODIVIDE);
  // Test overflow
  v = pow(10, 310.0);
  _statusfp2(&x86, &sse);
  assert(sse & _EM_OVERFLOW);
  return 0;
}
于 2009-02-22T15:38:24.557 回答
0

这些功能是标准规定的,因此您在移植时应该没有问题。你遇到了什么确切的错误?

于 2009-02-22T12:58:24.803 回答