Delphi - 比较两个"Real"数字变量

j.k*_*par 7 delphi floating-point

我对"Real"类型的两个变量的比较有问题.一个是数学运算的结果,存储在数据集中,第二个是表单中的编辑字段的值,由StrToFloat转换并存储到"Real"变量.问题是这样的: 121,97不等于121,97

正如你所看到的,该程序试图告诉我,121,97不等于121,97 ...我已经阅读了 这个主题,我并不完全确定,这是同样的问题.如果是,那么变量中存储的数字不会是完全相同的最接近可表示的数字,对于121.97是121.96999 99999 99998 86313 16227 83839 70260 62011 71875多少?

现在让我们说它们不会存储为最接近的可表示数字.我怎样才能找到它们的存储方式?当我查看"CPU"调试窗口时,我完全迷失了.我看到地址,那些值应该是,但没有什么甚至类似于一些二进制,十六进制或实际数字的任何表示...我承认,高级调试对我来说是未知的宇宙......

编辑:这两个值确实略有不同.

在此输入图像描述

好的,我不需要了解一切.虽然我没有处理金钱,但最多会有3位小数,所以"货币"就是出路

顺便说一句:计算方法是:

DATA[i].Meta.UnUsedAmount := DATA[i].AMOUNT - ObjQuery.FieldByName('USED').AsFloat;
Run Code Online (Sandbox Code Playgroud)

在这种情况下,它是3695 - 3573.03

Joh*_*ica 10

由于未知原因,您无法在监视列表中将浮点值(单/双或实数48)视为十六进制.

但是,您仍然可以通过将其视为内存转储来查看十六进制表示.
方法如下:将变量添加到监视列表中.
右键单击手表 - >编辑观察...
查看为memory dump

在此输入图像描述

现在,您可以比较调试器中的两个值.

永远不要使用浮动货币金额
您当然知道您不应该使用浮动来计算金钱.
你会因为舍入而遇到各种各样的麻烦,比较也不会按照你想要的方式运行.
如果你想用钱工作,请使用currency类型.它没有这些问题,支持4位小数,可以使用=运算符进行比较,没有舍入问题.

在数据库中,您使用moneycurrency数据类型.