您好,登錄后才能下訂單哦!
這篇文章主要介紹“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還可以產生字母的,但是我想這自定義函數添加個字母應該也不會太難~
到此,關于“PHP原生函數和自定義函數對比”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。