我可以将我的Delphi代码包装在如下所示的未记录的{$finiteFloat OFF|ON}
编译器指令中,以在函数期间禁用浮点异常吗?
{$finiteFloat OFF}
a := 5.0;
b := 0.0;
c := a/b; // do not raise exception here!
{$finiteFloat ON}
我知道我可以使用{$ J}的常量,但我认为{$ finiteFloat}不能这样做,因为它的范围是全局的。谁能确认一下?
答案 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上需要此指令。