Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1120936
  • 博文数量: 113
  • 博客积分: 2422
  • 博客等级: 大尉
  • 技术积分: 1393
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-25 17:54
文章分类
文章存档

2016年(1)

2014年(8)

2013年(7)

2012年(13)

2011年(42)

2010年(26)

2009年(6)

2008年(6)

2007年(4)

我的朋友

分类:

2010-08-07 16:54:51

PHP学习记录(浮点型)

浮点数(也叫浮点数,双精度数或实数),PHP语法定义:

$a 1.234
$b 1.2e3
$c 7E-10;
?>

正则表达示如下:

浮点数     [0-9]+
双精度型:   ([0-9][\.]{LNUM}) | ({LNUM}[\.][0-9]*)
指数表达式: [+-]?(({LNUM} | {DNUM}) [eE][+-]? {LNUM})

=========================
最大浮点数php代码如下:

  function float_max($mul = 2, $affine = 1) {
    $max = 1; $omax = 0;
    while((string)$max != 'INF') { $omax = $max; $max *= $mul; }

    for($i = 0; $i < $affine; $i++) {
      $pmax = 1; $max = $omax;
      while((string)$max != 'INF') {
        $omax = $max;
        $max += $pmax;
        $pmax *= $mul;
      }
    }
    return $omax;
  }
  echo "最大浮点数:" ;var_dump(float_max());
?>
=========================
结果如下(与平台相关):
最大浮点数:float(1.79769313486E+308)

关于浮点数精度的注意事项:

简单的十进制分数如同 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 错误。

阅读(2371) | 评论(0) | 转发(0) |
0

上一篇:php学习记录

下一篇:PHP学习记录(String)

给主人留下些什么吧!~~