<code>php</code><code><br><br><br><br><br> $b=(0.1+0.7)*10; echo intval($b); </code>
为什么输出的是0.7?不是0.8?
<code>php</code><code><br><br><br><br><br> $b=(0.1+0.7)*10; echo intval($b); </code>
为什么输出的是0.7?不是0.8?
跟浮点数运算的性质有关,你直接输出$b会发现计算的结果是0.7999999,而intval是向下取整的,可以改用ceil。
参见:http://php.net/manual/en/language.types.integer.php#language.types.integer.casting
我们来看一下$b
的二进制形式:
<code><?php $b = (0.1 + 0.7) * 10; $c = unpack('H16hex', pack('d', $b)); echo $c['hex']; ?> </code>
输出:
<code>ffffffffffff1f40 </code>
由于little-endian
, 实际上是 0x401fffffffffffff
,这个数字按照IEEE754
标准转换为十进制的话 就是
<code>7.999999999999999 </code>
php
找不到合适的测试方法,你可以用Java
试下以下代码
<code>System.out.println(Double.longBitsToDouble(0x401fffffffffffffL)); </code>
其他的内容, 楼上几位都解释得很清楚了~
http://www.laruence.com/2013/03/26/2884.html