php 浮点数精度值实例程序详解

php中浮点数的精度值是用来控制输出该浮点数时使用的,可以理解为控制输出的位数,精度值不同,看到输出结果也可能不一样,注意:其内部还是按照实际值存储的,当两个浮点数进行四则运算时,用的还是其本来的值。

php的配置文件中使用precision来设定全局指定浮点数的精度值,似乎每个发行版,它的默认设置都不太一样,我在window下看到是12,在linux下看到此值是14,当然也可以通过程序中使用ini_set来改变全局设置,例如:

ini_set("precision", "15");

对于精度我一直理解为小数点后保留多少,那么在php的浮点数中是这样的么?答案是否定的。

浮点数其实是整数部分和小数部分组成,这里的精度是指整数部分的位数加小数部分的位数不能超过其精度最大值,如果超过,则按照四舍五入的方法截断到最大的精度值。整数部分如果是0,则不计位数,小数部分末尾0也不计入位数。另外对于同一个数,precision的不同,可能显示的出来表现形式也不一样。下面通过例子的方式来说明。

整数部分为 0 情况,代码如下:

  1. $num = 0.12345600000000000; 
  2.  //整数部分为0 ,位数为 0 ,小数部分末尾的 0 不计入位数,所以总位数为 6 
  3.  ini_set("precision""12"); 
  4.  echo $num// 0.123456 
  5.  //未超过精度值,显示的结果为 0.123456 
  6.  ini_set("precision""3"); 
  7.  echo $num// 0.123 
  8.  //超过精度值,保留3位 
  9.  ini_set("precision""5"); 
  10.  echo $num// 0.12346 
  11.  //超过精度值,保留5位这种情况下,精度值等价于小数点后保留几位。 

整数部分大于 0 情况,代码如下:

  1. $num = 12.12345600000000000; 
  2.  //整数部分为12 ,位数为 2 ,小数部分末尾的 0 不计入位数,位数为6,所以总位数为 2 + 6 
  3.  ini_set("precision""12"); 
  4.  echo $num// 12.123456 
  5.  //未超过精度值,显示的结果为 12.123456 
  6.  ini_set("precision""3"); 
  7.  echo $num// 12.1 
  8.  //超过精度值,整数部分位数为 2 ,所以只保留一位小数 
  9.  ini_set("precision""5"); 
  10.  echo $num// 12.123 
  11.  //超过精度值,整数部分位数为 2 ,所以只保留3位小数可以看到小数点后保留的位数跟精度已经整数部分的位数有关。 

整数部分大于 0 情况 之二,代码如下:

  1. $num = 12345678.12345600000000000; 
  2. //整数部分为12345678 ,位数为 8 ,小数部分末尾的 0 不计入位数,位数为6,所以总位数为 8 + 6 
  3. ini_set("precision""12"); 
  4. echo $num// 12345678.1235 
  5. //超过精度值,显示的结果为 12345678.1235 
  6. ini_set("precision""3"); 
  7. echo $num// 1.23E+7 
  8. //超过精度值,且整数部分位数超过精度,小数部分舍弃,且整数部分只取3位 
  9. ini_set("precision""5"); 
  10. echo $num// 12346000 
  11. //超过精度值,且整数部分位数超过精度,小数部分舍弃,且整数部分只取5位 

上述例子中可以看到,精度值也关系到整数部分的截取,注意到最后两个例子中显示的方式不一样,一个是使用科学计数法,一个是后面用 0 补,通过实验得出的结论是当整数部分的位数减去 精度值 大于 4 的时候,使用科学计数法的方式,否则后面用 0 补,换句话说,就是整数部分位数超过精度值后,截断后,补 0 的个数不会超过 4.

浮点数运算,代码如下:

  1. $num1 = 1331625729.687; 
  2.  $num2 = 1331625730.934; 
  3.  ini_set("precision""8"); 
  4.  echo $num1 . ' 
  5. '; 
  6.  echo $num2 . ' 
  7. '; 
  8.  $sub = $num1 – $num2
  9.  echo $sub . ' 
  10. '; 
  11. //输出的结果为: 
  12. /* 
  13.  1331625700 
  14.  1331625700 
  15.  -1.247 
  16. */ 

上述例子就说明了精度值只是控制显示结果,内部存储还是原始值,所以 $sub 的值为1331625729.687减1331625730.934。

PHP内置的echo, var_dump,json_encode,字符串拼接等函数(指令)在显示浮点数时都有问题,导致精度丢失.实例代码如下:

  1. <?php 
  2.    $a = 1315537636.338467; 
  3.    printf("%f"$a); echo "n"
  4.    echo $a . "n"
  5.    echo $aecho "n"
  6. ?> 
  7.   /*结果 
  8.   1315537636.338467 
  9.   1315537636.3385 
  10.   1315537636.3385 
  11. */ 

也就是说,用PHP最顺手的方法将浮点数转成字符串或者显示是不行的,必须使用printf/sprintf将浮点数转成字符串.

波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » php 浮点数精度值实例程序详解

29 评论

  1. tadalafil 20mg sale otc cialis clomipramine 25mg for sale

  2. buy norvasc 10mg pill cialis pill tadalafil 5mg ca

  3. motilium sale flexeril pill cyclobenzaprine 15mg tablet

  4. buy generic trazodone suhagra cheap sildenafil 100mg pills

  5. adalat 10mg for sale aceon 4mg uk order fexofenadine 120mg for sale

  6. ramipril 10mg cheap ramipril pills etoricoxib over the counter

  7. clobetasol price clobetasol drug order cordarone 200mg pill

  8. buy tadacip 10mg sale trimox 250mg uk order amoxicillin sale

  9. Nice article inspiring thanks. Hello Administ . Metropol Halı Karaca Halı Öztekin ve Selçuklu Halı Cami Halısı ve Cami Halıları Türkiye’nin En Büyük Cami Halısı Fabrikasıyız…

发表评论

Hi, 如果你对这款模板有疑问,可以跟我联系哦!

联系站长
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡