展会信息港展会大全

PHP学习记录(浮点型) android软件开发教程
来源:互联网   发布日期:2016-03-02 15:50:21   浏览:1188次  

导读:<?php$a = 1.234; $b = 1.2e3; $c = 7E-10;?>正则表达示如下:浮点数: [0-9]+双精度型: ([0-9][.]{LNUM}) |...

<?php

$a = 1.234;

$b = 1.2e3;

$c = 7E-10;

?>

正则表达示如下:

浮点数:[0-9]+

双精度型:([0-9][.]{LNUM}) | ({LNUM}[.][0-9]*)

指数表达式: [+-]?(({LNUM} | {DNUM}) [eE][+-]? {LNUM})

=========================

最大浮点数php代码如下:

<?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 错误。

赞助本站

人工智能实验室

相关热词: 开发 编程 android

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港