在单个函数期间禁用浮点异常

时间:2016-01-13 21:25:11

标签: delphi delphi-xe6

我可以将我的Delphi代码包装在如下所示的未记录的{$finiteFloat OFF|ON}编译器指令中,以在函数期间禁用浮点异常吗?

{$finiteFloat OFF}
a := 5.0;
b := 0.0;
c := a/b;  // do not raise exception here!
{$finiteFloat ON}

我知道我可以使用{$ J}的常量,但我认为{$ finiteFloat}不能这样做,因为它的范围是全局的。谁能确认一下?

1 个答案:

答案 0 :(得分:6)

此编译器指令仅适用于现已解散的.net编译器,这解释了为什么没有记录。因此,由于您没有使用.net编译器,因此该指令对您的程序没有影响。要使用编译器屏蔽浮点异常,请调用SetExceptionMask

来自Hallvard Vassbotn的这个article显示了以下示例代码:

{$IFDEF CLR}
  {$FINITEFLOAT OFF}
{$ELSE}
  Math.SetExceptionMask([exInvalidOp, exDenormalized, exZeroDivide, exOverflow, 
    exUnderflow, exPrecision]);
{$ENDIF}
One := 0;
Two := 42;
Three := Two / One; // Returns +Inf, no exception raised

请注意Hallvard如何仅将$FINITEFLOAT与.net编译器一起使用。该文章还解释了为什么.net上需要此指令。