php-timeit估計php函數的執行時間

來源:互聯網
上載者:User
  首先,前段時間利用手頭的日本VPS搭建了一個google代理,訪問速度還行,分享給大家:

  Googleguge不行了,就打119

  Google:guge119.com

  Google學術:scholar.guge119.com

  有時候我們在PHP效能最佳化的時候,需要知道某個函數的執行時間,在Python中,有timeit模組,在PHP中不知道有沒有類似的模組?

  於是,我自己寫了一個簡單的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.0282800197601320.0041000843048096

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

以上就介紹了php-timeit估計php函數的執行時間,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.