我对“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