//$usec:当前微秒数,$sec:当前秒数
list ( $usec, $sec ) = explode ( ' ', microtime () );
$time1 = ( float ) $usec + ( float ) $sec;list ( $usec, $sec ) = explode ( ' ', microtime () );
$time2 = ( float ) $usec + ( float ) $sec;echo $time2 - $time1;结果输出一个类似这样的数:3.40938568115E-5 问题:
单独打印$usec和$sec,输出这样的数:0.95312700 1326693637
$time输出类似这样的数:1326693637.95
那为什么用$time1-$time2输出成了“3.40938568115E-5 ”???谢谢
   

解决方案 »

  1.   

    可以自己定义格式echo sprintf('%.16F', $time2 - $time1);
      

  2.   

    对源码了解比较有限,若有错误敬请斧正php执行,有个过程是转换成opcode,而echo 转换为ZEND_ECHO,最终由zend_print_variable去执行此函数执行前会先
    zend_make_printable_zval,对各种数据类型转换为字符串
    例如bool型的,打印出1,0,数组打印出“Array”都在这个函数中完成科学计数法的数字,直接转换成字符串了,,,,想要期望的格式,你就要在代码中控制
      

  3.   

    因为你的  $time2 - $time1 数值太小,大概等于 0.0000340938568115
    这样前面的几个0影响精度显示,所以自动改为科学计数法
    3.40938568115E-5 相当于 3.40938568115 * 10 ^ -5
      

  4.   

    其实我的意思是:
    $time1和$time2都是类似于这样的数:1326693637.95
    那他们相减也应该是两位的小数啊,为什么小数点后面出来那么多??
      

  5.   

    因为后面的小数部分根本没有全部显示出来,以前说过很多次了,当时我提问之前就知道这个问题了,但是有时候真碰到了如果不注意还是不容易被发现,http://topic.csdn.net/u/20111102/11/b7abbb09-8325-434d-8bbc-6843ba68ebee.html