上个月我们遇到了佣金支付方面的问题。美元金额超过了整数可以容纳的实际值。这是自应用程序写入以来第一次发生。问题四舍五入Int64和负数,我在这里失踪了什么?
clist : tstringlist;
clist.objects[dex]:= tobject(round((10000*DM.QryComm1.fieldbyname('COSS_NET_CHECK_AMT').asfloat)) + integer(clist.objects[dex]));
的美元金额是$ 215,980.72我们通过10000繁殖并获得2159807200.答案最大的整数为2147483647
所以我们增加为Int64的整数。
clist.objects[dex]:= tobject(round((10000*DM.QryComm1.fieldbyname('COSS_NET_CHECK_AMT').asfloat)) + int64(clist.objects[dex]))
,我们遇到的问题是如果一个负整数来通过时,我们使用的Int64,的4294428496缺省值被放置在tstringlsit而不是实际的数值。这只发生在负面情况下。正数很好。
我们一直在研究所有的网络,并找不到解决方案。
这里是原来的代码.....
while not DM.QryComm1.eof do
begin
.
.
{Sum net amount for each BVCICI_ID}
dex:=clist.indexof(BVCICI_ID);
if dex<> -1 then
clist.objects[dex]:= tobject(round((10000*DM.QryComm1.fieldbyname('COSS_NET_CHECK_AMT').asfloat)) +
integer(clist.objects[dex]))
else
clist.addobject(BVCICI_ID, tobject(round(DM.QryComm1.fieldbyname('COSS_NET_CHECK_AMT').asfloat*10000)));
在货币计算中使用二进制浮点是非常糟糕的风格。 – CodesInChaos
'10000 *'的存在让人怀疑你是否应该真正做'AsDecimal'。 –