程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP原生函數一定好嗎?,PHP原生函數

PHP原生函數一定好嗎?,PHP原生函數

編輯:關於PHP編程

PHP原生函數一定好嗎?,PHP原生函數


今天在閱讀kohana源碼中的Arr類的時候發現了這樣一個函數

復制代碼 代碼如下:
 /**
  * Fill an array with a range of numbers.
  *
  *     // Fill an array with values 5, 10, 15, 20
  *     $values = Arr::range(5, 20);
  *
  * @param   integer $step   stepping
  * @param   integer $max    ending number
  * @return  array
  */
 public static function range($step = 10, $max = 100)
 {
  if ($step < 1)
   return array();

  $array = array();
  for ($i = $step; $i <= $max; $i += $step)
  {
   $array[$i] = $i;
  }

  return $array;
 }
 

    看到這裡的時候,我發現php的原生函數也是可以實現這個功能的,忽然想到之前聽到過的一個前輩關於php性能優化的說法——PHP為我們提供了那麼多的原生函數,我們盡量用原生函數解決問題。於是我就做了個測試,看看php原生函數性能究竟比自己寫的快多少。要測試的函數有原生函數range()和上面的函數_range(),這裡加下劃線開始是因為重寫原生函數range()會報錯“Fatal error: Cannot redeclare range() in”。

復制代碼 代碼如下: 
 function _range($step = 10, $max = 100)
 {
  if ($step < 1)
   return array();
  $array = array();
  for ($i = $step; $i <= $max; $i += $step)
  {
   $array[$i] = $i;
  }
  return $array;
 }
 $time['begin'] = microtime(true);
 $tmp = range(0,1000000,3);
 //$tmp = _range(0,1000000,3);
 $time['end']   = microtime(true);
 echo $time['end'] - $time['begin'].'s'."\r";
 echo (memory_get_peak_usage()/1024/1024)."M";

    分別用原生函數和自定義函數進行測試,在產生0~1000000之間所有的3的倍數時,結果出乎我的意料:

首先是使用原生函數的結果:

 

下面是使用自定義函數的結果:

 

為了結果比較准確,我在做個圖表統計

統計次數 原生函數range() 自定義函數_range()
(0,1000000,3) 5.155E-3s 27.5530M 1.907E-5s 0.1241M
(0,1000000,2) 7.479E-3s 40.2688M 1.811E-5s 0.1241M
(0,1000,1) 8.16E-5s 0.1620M 2.649E-5s 0.1241M
    從表中可以看出產生隨機數時自定義函數比原生函數要節省內存和時間,而且原生函數在生成大量隨機數時特別耗內存,消耗時間也特別多,而自定義函數在這方面則表現得好,產生的內存和消耗的時間基本穩定,看來前面那位前輩說的不一定完全正確哦,但是這裡要注意我們這裡的自定義函數只能生成數字,而原生的range還可以產生字母的,但是我想這自定義函數添加個字母應該也不會太難~

    看來kohana官方對range這個函數很是了解,對php內核中該函數的復雜度也很了解,所以這個小優化才可以做這麼好,太厲害了!!!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved