//$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 ”???谢谢
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 ”???谢谢
zend_make_printable_zval,对各种数据类型转换为字符串
例如bool型的,打印出1,0,数组打印出“Array”都在这个函数中完成科学计数法的数字,直接转换成字符串了,,,,想要期望的格式,你就要在代码中控制
这样前面的几个0影响精度显示,所以自动改为科学计数法
3.40938568115E-5 相当于 3.40938568115 * 10 ^ -5
$time1和$time2都是类似于这样的数:1326693637.95
那他们相减也应该是两位的小数啊,为什么小数点后面出来那么多??