2

我有一些价格和折扣金额将存储在 PHP 代码的配置变量中。我想知道是否需要将它们存储为字符串。

例如,执行以下操作是否安全?

$price = 14.95;
$volume_discount = 0.3;

还是我应该将它们存储为字符串?

$price = '14.95';
$volume_discount = '0.3';

我知道比较浮点数和用浮点数进行计算会产生意想不到的结果,除非你使用 BC Math。但我想知道是否按原样打印出存储的值。我尝试回显浮动版本,它们按预期显示,但我想知道这是否可靠。

注意:我使用了预期这个词来解释外行人的期望。正如 Eric 指出的那样,精确的十进制浮点数实际上不是预期的结果。

编辑:我现在关心的代码检查数量并确定是否应该应用折扣。然后进行以下计算:

$price -= round($price * $volume_discount, 2);

我通常number_format用来格式化显示价格,但我注释掉了我的测试格式。到目前为止,无论价格或折扣值如何,PHP 都给了我想要的结果。然而,JavaScript 并不总能给我想要的结果。这就是让我再次查看我的 PHP 代码的原因。

显然,我将调整 JavaScript,因为这是错误出现的地方,但我试图决定是否需要重构我的 PHP 代码。

向我说明问题的数字是 149.95 * 0.3。PHP 显示 44.985,JavaScript 显示 44.98499999999999。所以,即使四舍五入到小数点后两位,我也会得到不同的数字。

4

1 回答 1

2

解释十进制数字“14.95”并将其存储在二进制浮点对象中需要浮点运算:从十进制到二进制浮点的转换。因此,这是一个浮点运算,会出现舍入误差。

当编译器或解释器或在运行时解释源文本时,可能会发生这种转换,但它确实会发生并且会出现舍入错误。

(您的问题断言与浮点数进行比较和计算会产生意想不到的结果。仅当您不期望操作遵守这些操作的规范时,这才是正确的。您可以通过学习规范来避免意外结果,从而了解要做什么预计。)

于 2013-02-18T05:27:17.473 回答