ColdFusion 的 DecimalFormat() 函数中这是怎么回事?我怎样才能得到正确的结果?
<cfset number1 = 20.5/80 * 100 />
<cfset number2 = 18.125 />
<cfset number3 = 6.875 />
<cfoutput>
DecimalFormat(#number1#): #DecimalFormat(number1)#<br />
DecimalFormat(#number2#): #DecimalFormat(number2)#<br />
DecimalFormat(#number3#): #DecimalFormat(number3)#
</cfoutput>
输出:
DecimalFormat(25.625): 25.62
DecimalFormat(18.125): 18.13
DecimalFormat(6.875): 6.88
而不是输出:
DecimalFormat(25.625): 25.63
DecimalFormat(18.125): 18.13
DecimalFormat(6.875): 6.88
作为数学计算结果的变量似乎使 DecimalFormat() 的行为有所不同。有什么快速解决办法,而不深入研究java?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
我认为问题不在于
DecimalFormat()
,而是典型的浮点舍入错误。请参阅:
PrecisionEvaluate()
I think the problem is not
DecimalFormat()
, but the typical floating-point rounding errors.see:
PrecisionEvaluate()
DecimalFormat 是一个格式化函数。不是数学函数。它的工作不是为您四舍五入您的数字,不幸的是 CF 缺乏良好的小数数学函数,因此您必须编写自己的函数。
这是有人在 CF livedocs 页面上为 round() 写的一篇文章:
DecimalFormat is a formatting function. Not a Mathematical function. Its job is not to round your number for you, unfortunately CF lacks good mathematical functions for decimals so you will have to write your own.
Here is one someone wrote on the CF livedocs page for round():
快速解决方法是将第 1 行更改为
number1 = NumberFormat(20.5/80 * 100,'9.999')
A quick fix would be to change line 1 to
number1 = NumberFormat(20.5/80 * 100,'9.999')
请参阅 CF 文档 NumberFormat 并进行一轮页面搜索以查看一些具体信息。
Please see the CF documentation NumberFormat and do a page search on round to see some specific information.