zl程序教程

您现在的位置是:首页 >  其它

当前栏目

phpmicrotime获取浮点的时间戳

获取 时间 浮点
2023-06-13 09:14:16 时间
一直以来用这个函数获取:
复制代码代码如下:

functionmicrotime_float(){
list($usec,$sec)=explode("",microtime());
return((float)$usec+(float)$sec);
}

看到别人的源码中用microtime(true),查了下手册,原来从PHP5.0.0开始,microtime增加了这个参数。
引用
复制代码代码如下:

mixedmicrotime([boolget_as_float])
microtime()当前Unix时间戳以及微秒数。本函数仅在支持gettimeofday()系统调用的操作系统下可用。
如果调用时不带可选参数,本函数以"msecsec"的格式返回一个字符串,其中sec是自Unix纪元(0:00:00January1,1970GMT)起到现在的秒数,msec是微秒部分。字符串的两部分都是以秒为单位返回的。
如果给出了get_as_float参数并且其值等价于TRUE,microtime()将返回一个浮点数。
注意:get_as_float参数是PHP5.0.0新加的。

如果程序肯定在PHP5以上的环境运行,那么就直接使用microtime(true)吧,比使用microtime_float函数至少快两倍。以下是我简单测试的程序代码。
复制代码代码如下:
<?php
functionmicrotime_float3(){
returnmicrotime(true);
}
functionmicrotime_float2(){
if(PHP_VERSION>5){
returnmicrotime(true);
}else{
list($usec,$sec)=explode("",microtime());
return((float)$usec+(float)$sec);
}
}
functionmicrotime_float(){
list($usec,$sec)=explode("",microtime());
return((float)$usec+(float)$sec);
}
functionruntime($t1){
returnnumber_format((microtime_float()-$t1)*1000,4)."ms";
}
$t1=microtime_float();
for($i=0;$i<10000;$i++){
microtime_float();
}
echo"microtime_float=====";
echoruntime($t1)."<br>";
$t1=microtime(true);
for($i=0;$i<10000;$i++){
microtime(true);
}
echo"microtime_true=====";
echoruntime($t1)."<br>";
$t1=microtime(true);
for($i=0;$i<10000;$i++){
microtime_float2();
}
echo"microtime_float2=====";
echoruntime($t1)."<br>";
$t1=microtime(true);
for($i=0;$i<10000;$i++){
microtime_float3();
}
echo"microtime_float3=====";
echoruntime($t1)."<br>";
?>

本机winxp运行结果:
microtime_float=====109.5631ms
microtime_true=====38.8160ms
microtime_float2=====52.7902ms
microtime_float3=====45.0699ms
Linux上运行结果:
microtime_float=====47.2510ms
microtime_true=====9.2051ms
microtime_float2=====16.3319ms
microtime_float3=====12.2800ms
在PHP5的环境下,直接使用microtime(true);显然是最快的。microtime_float2和microtime_float3都可以在不改变原有程序的情况下,直接修改函数内容来实现性能的轻微提升。microtime_float2可以做为兼容旧版本的写法。