测试php速度,测试 - 如何衡量用PHP编写的代码的速度?

我想与您分享一个自制函数,用于测量任何现有函数的速度,最多10个参数:

function fdump($f_name='', $f_args=array()){

$f_dump=array();

$f_result='';

$f_success=false;

$f_start=microtime();

$f_start=explode(' ', $f_start);

$f_start=$f_start[1] + $f_start[0];

if(function_exists($f_name)){

if(isset($f_args[0])&&is_array($f_args[0])){

if($f_result=$f_name($f_args)){

$f_success=true;

}

}

elseif(!isset($f_args[1])){

if($f_result=$f_name($f_args[0])){

$f_success=true;

}

}

elseif(!isset($f_args[2])){

if($f_result=$f_name($f_args[0],$f_args[1])){

$f_success=true;

}

}

elseif(!isset($f_args[3])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2])){

$f_success=true;

}

}

elseif(!isset($f_args[4])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3])){

$f_success=true;

}

}

elseif(!isset($f_args[5])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3],$f_args[4])){

$f_success=true;

}

}

elseif(!isset($f_args[6])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3],$f_args[4],$f_args[5])){

$f_success=true;

}

}

elseif(!isset($f_args[7])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3],$f_args[4],$f_args[5],$f_args[6])){

$f_success=true;

}

}

elseif(!isset($f_args[8])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3],$f_args[4],$f_args[5],$f_args[6],$f_args[7])){

$f_success=true;

}

}

elseif(!isset($f_args[9])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3],$f_args[4],$f_args[5],$f_args[6],$f_args[7],$f_args[8])){

$f_success=true;

}

}

elseif(!isset($f_args[10])){

if($f_result=$f_name($f_args[0],$f_args[1],$f_args[2],$f_args[3],$f_args[4],$f_args[5],$f_args[6],$f_args[7],$f_args[8],$f_args[9])){

$f_success=true;

}

}

}

$f_end=microtime();

$f_end=explode(' ', $f_end);

$f_end=$f_end[1] + $f_end[0];

$f_time=round(($f_end - $f_start), 4);

$f_dump['f_success']=$f_success;

$f_dump['f_time']=$f_time;

$f_dump['f_result']=$f_result;

var_dump($f_dump);exit;

//return $f_result;

}

function do_stuff($arg1='', $arg2=''){

return $arg1.' '.$arg2;

}

fdump('do_stuff',array('hello', 'world'));

返回

array(3) {

["f_success"]=>

bool(true)

["f_time"]=>

float(0) //too fast...

["f_result"]=>

string(11) "hello world"

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值