我有两个变量的比较问题" Real"类型。一个是数学运算的结果,存储在数据集中,第二个是表单中的编辑字段的值,由StrToFloat转换并存储到" Real"变量。问题是这样的:
正如你所看到的,程序试图告诉我,121,97不等于121,97 ......我读过
this topic,我并不完全确定,这是同样的问题。如果是,那么存储在变量中的数字不会是完全相同的最接近的可表示数字,对于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;
在这种情况下,它是3695 - 3573.03
答案 0 :(得分:10)