加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

delphi – 为什么RoundTo的结果(87.285,-2)=> 87.28

发布时间:2020-12-15 10:15:57 所属栏目:大数据 来源:网络整理
导读:我预计结果将是87.29。我也尝试过SimpleRoundTo,但产生相同的结果。 在帮助中也有一个“奇怪”的例子: MS-帮助://embarcadero.rs2010/vcl/Math.RoundTo.html RoundTo(1.235,-2) = 1.24RoundTo(1.245,-2) = 1.24 //??? 有人知道我需要得到87.29的结果吗?
我预计结果将是87.29。我也尝试过SimpleRoundTo,但产生相同的结果。

在帮助中也有一个“奇怪”的例子:
MS-帮助://embarcadero.rs2010/vcl/Math.RoundTo.html

RoundTo(1.235,-2) => 1.24
RoundTo(1.245,-2) => 1.24 //???

有人知道我需要得到87.29的结果吗?我的意思是:如果最后一个数字> = 5向上舍入, 5回合。正如学校所教的:)

我使用Delphi2010和SetRoundMode(rmNearest)。我也试过rmTruncate。
值87.285存储在双变量中。

也怪:

SimpleRoundTo(87.285,-2) => 87.29

x := 87.285; //double
SimpleRoundTo(x,-2) => 87.28

解决方法

87.285不完全可表示,最近的双倍略小。

经典的浮点参考是What Every Computer Scientist Should Know About Floating-
Point Arithmetic。

对于基于货币的计算,如果确实是这样,您应该使用基数10数字类型而不是基数2浮点数。在Delphi中,即货币。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读