使用php-timeit估計php函數的執行時間,php-timeitphp_PHP教程

來源:互聯網
上載者:User

使用php-timeit估計php函數的執行時間,php-timeitphp


廢話不多說了,直接把我寫的timeit函數分享給大家,具體內容如下:

/** * Compute the delay to execute a function a number of time * @param $count Number of time that the tests will execute the given function * @param $function  the function to test. Can be a string with parameters (ex: 'myfunc(123, 0, 342)') or a callback * @return float   Duration in seconds (as a float) */function timeit($count, $function) { if ($count <= 0){  echo "Error: count have to be more than zero";  return -1; } $nbargs = func_num_args(); if ($nbargs < 2) {  echo 'Error: No Funciton!';  echo 'Usage:';  echo "\ttimeit(count, 'function(param)')";  echo "\te.g:timeit(100, 'function(0,2)')";  return -1;      // no function to time } // Generate callback $func = func_get_arg(1); $func_name = current(explode('(', $func)); if (!function_exists($func_name)) {  echo 'Error: Unknown Function';  return -1;     // can't test unknown function } $str_cmd = ''; $str_cmd .= '$start = microtime(true);'; $str_cmd .= 'for($i=0; $i<'.$count.'; $i++) '.$func.';'; $str_cmd .= '$end = microtime(true);'; $str_cmd .= 'return ($end - $start);'; return eval($str_cmd);}

  測試一下自己寫的一個求根演算法與系統內建求根函數的執行時間,如下:

//取平方根function sqrt_nd($num){ $value = $num; while(abs($value*$value -$num) > 0.001){  $value = ($value + $num/$value)/2; } return $value;}print timeit(1000, 'sqrt_nd(5)');print "\n";print timeit(1000, 'sqrt(5)');

  測試結果如下:

0.028280019760132
0.0041000843048096

  可見,內建求根函數比自訂的求根函數快了6倍多~~

php中檢測函數執行時間的功能使用的方法

PHP 中的 microtime() 函數可以實現

microtime() 函數返回當前 Unix 時間戳記和微秒數。

microtime(get_as_float)

參數說明
get_as_float 如果給出了 get_as_float 參數並且其值等價於 TRUE,該函數將返回一個浮點數。

本函數僅在支援 gettimeofday() 系統調用的作業系統下可用。

例如:

<?php$start_time = microtime(true);for($i=1;$i<=1000;$i++){echo $i.'
';}$end_time = microtime(true);

echo '迴圈執行時間為:'.($end_time-$start_time).' s';
?>

http://www.bkjia.com/PHPjc/1052066.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/1052066.htmlTechArticle使用php-timeit估計php函數的執行時間,php-timeitphp 廢話不多說了,直接把我寫的timeit函數分享給大家,具體內容如下: /** * Compute the delay to...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.