全部博文(113)
分类:
2010-08-07 16:54:51
$a = 1.234;
$b = 1.2e3;
$c = 7E-10;
?>
正则表达示如下:
浮点数: [0-9]+
双精度型: ([0-9][\.]{LNUM}) | ({LNUM}[\.][0-9]*)
指数表达式: [+-]?(({LNUM} | {DNUM}) [eE][+-]? {LNUM})
关于浮点数精度的注意事项:
简单的十进制分数如同 0.1 或 0.7 在转换为内部二进制的格式会丢失精度:
例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是7.9。
就是不可能精确的用有限位数表达某些十进制分数。
例如,十进制的 1/3 变成了 0.3。
所以
1。永远不要相信浮点数结果精确到了最后一位,
2。也永远不要比较两个浮点数是否相等。
3。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。
自 PHP 5 起,如果试图将对象转换为浮点数,会发出一条 E_NOTICE 错误。