为什么PHP浮点除法和POW会给出错误的结果和意外的结果?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了为什么PHP浮点除法和POW会给出错误的结果和意外的结果?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1254字,纯文字阅读大概需要2分钟。
内容图文
![为什么PHP浮点除法和POW会给出错误的结果和意外的结果?](/upload/InfoBanner/zyjiaocheng/689/e4e9e527697c4897ae945284e96e744f.jpg)
有谁知道为什么会这样以及是否可以解决.我正在比较C和PHP的结果,但是PHP给了我不同的结果.
如果需要,我可以提供一些代码,但是以前有没有人经历过?
PHP代码
$tempnum = 1.0e - 5 * -44954; // substr($line1,53,6); $bstar = $tempnum / pow(10.0, 3); $bstar gives me -0.00044954 in PHP but it should be -0.000450
C代码
double tempnum = 1.0e - 5 * -44954; double bstar = tempnum / pow(10.0, 3); printf bstar gives me -0.000450
到目前为止,感谢您的答复,但是PHP如何得出这个结论…
$twopi = 6.28318530717958623; /* 2*Pi */ $xmnpda= 1440; //1.44E3 ; /* Minutes per day */ $temp = (($twopi/$xmnpda)/$xmnpda); $xndt2o = -0.000603; $xndt2o = $xndt2o * $temp; echo $xndt2o gives me -1.8256568188E-9 in PHP but in C it gives me -0.000000
我不知道PHP的全部含义.
解决方法:
精度有限的浮点格式几乎总是有点不准确,并且这些不正确之处会相互叠加并以意想不到的方式表现出来.通常,结果并没有那么多错误,但是唯一的问题是您没有想到不正确的地方.有关一般说明,请阅读The Floating-Point Guide.
也许与您的问题最相关:永远不要期望计算序列在平台之间产生完全相同的结果,因为有许多因素可能导致执行不同的实际基本操作. This paper explains it in great detail..
对于您所看到的差异的更简单的解释可能是,PHP代码以某种方式仅在某处使用32位浮点数,因为该差异显示在小数点6/7左右,而32位浮点数的精度恰好在此结束.
内容总结
以上是互联网集市为您收集整理的为什么PHP浮点除法和POW会给出错误的结果和意外的结果?全部内容,希望文章能够帮你解决为什么PHP浮点除法和POW会给出错误的结果和意外的结果?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。