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