PHP原生函數(shù)一定好嗎?
今天在閱讀kohana源碼中的Arr類(lèi)的時(shí)候發(fā)現(xiàn)了這樣一個(gè)函數(shù)
/**
* 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;
}
看到這里的時(shí)候,我發(fā)現(xiàn)php的原生函數(shù)也是可以實(shí)現(xiàn)這個(gè)功能的,忽然想到之前聽(tīng)到過(guò)的一個(gè)前輩關(guān)于php性能優(yōu)化的說(shuō)法——PHP為我們提供了那么多的原生函數(shù),我們盡量用原生函數(shù)解決問(wèn)題。于是我就做了個(gè)測(cè)試,看看php原生函數(shù)性能究竟比自己寫(xiě)的快多少。要測(cè)試的函數(shù)有原生函數(shù)range()和上面的函數(shù)_range(),這里加下劃線(xiàn)開(kāi)始是因?yàn)橹貙?xiě)原生函數(shù)range()會(huì)報(bào)錯(cuò)“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";
分別用原生函數(shù)和自定義函數(shù)進(jìn)行測(cè)試,在產(chǎn)生0~1000000之間所有的3的倍數(shù)時(shí),結(jié)果出乎我的意料:
首先是使用原生函數(shù)的結(jié)果:
下面是使用自定義函數(shù)的結(jié)果:
為了結(jié)果比較準(zhǔn)確,我在做個(gè)圖表統(tǒng)計(jì)
統(tǒng)計(jì)次數(shù) 原生函數(shù)range() 自定義函數(shù)_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
從表中可以看出產(chǎn)生隨機(jī)數(shù)時(shí)自定義函數(shù)比原生函數(shù)要節(jié)省內(nèi)存和時(shí)間,而且原生函數(shù)在生成大量隨機(jī)數(shù)時(shí)特別耗內(nèi)存,消耗時(shí)間也特別多,而自定義函數(shù)在這方面則表現(xiàn)得好,產(chǎn)生的內(nèi)存和消耗的時(shí)間基本穩(wěn)定,看來(lái)前面那位前輩說(shuō)的不一定完全正確哦,但是這里要注意我們這里的自定義函數(shù)只能生成數(shù)字,而原生的range還可以產(chǎn)生字母的,但是我想這自定義函數(shù)添加個(gè)字母應(yīng)該也不會(huì)太難~
看來(lái)kohana官方對(duì)range這個(gè)函數(shù)很是了解,對(duì)php內(nèi)核中該函數(shù)的復(fù)雜度也很了解,所以這個(gè)小優(yōu)化才可以做這么好,太厲害了?。?!
相關(guān)文章
Linux(CentOS)下PHP擴(kuò)展PDO編譯安裝的方法
這篇文章主要介紹了Linux(CentOS)下PHP擴(kuò)展PDO編譯安裝的方法,詳細(xì)說(shuō)明了Linux下安裝PHP的PDO擴(kuò)展所涉及的相關(guān)技巧與詳細(xì)步驟,需要的朋友可以參考下2016-04-04一文詳解PHP連接MySQL數(shù)據(jù)庫(kù)的三種方式
PHP與MySQL的連接有三種API接口,分別是:PHP的MySQL擴(kuò)展 、PHP的mysqli擴(kuò)展 、PHP數(shù)據(jù)對(duì)象(PDO)。本文將詳解這三種方式的示例代碼,需要的可以參考一下2022-05-05PHP實(shí)現(xiàn)字節(jié)數(shù)Byte轉(zhuǎn)換為KB、MB、GB、TB的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)字節(jié)數(shù)Byte轉(zhuǎn)換為KB、MB、GB、TB的方法,結(jié)合實(shí)例形式分析了php針對(duì)字節(jié)數(shù)Byte的換算操作具體實(shí)現(xiàn)方法,涉及php數(shù)學(xué)運(yùn)算相關(guān)函數(shù)的使用,需要的朋友可以參考下2017-08-08PHP mkdir創(chuàng)建文件夾實(shí)現(xiàn)方法解析
這篇文章主要介紹了PHP mkdir創(chuàng)建文件夾實(shí)現(xiàn)方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11php中g(shù)et_meta_tags()、CURL與user-agent用法分析
這篇文章主要介紹了php中g(shù)et_meta_tags()、CURL與user-agent用法,以實(shí)例形式較為詳細(xì)的分析了get_meta_tags()、CURL與user-agent使用時(shí)的注意事項(xiàng)與用法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之五 簡(jiǎn)化函數(shù)調(diào)用
前幾篇系列文章,我比較關(guān)注的是 PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之一 重新組織你的函數(shù) 但是我覺(jué)得我還是沒(méi)有說(shuō)清楚,我自己也有很多不理解的地方,而且這篇是我的第一篇這方面的文章,有很多的紕漏,所以我會(huì)經(jīng)常性的去做修改,如果大家有好的意見(jiàn)不妨告知一、二2012-05-05php 讀取文件頭判斷文件類(lèi)型的實(shí)現(xiàn)代碼
以下是對(duì)使用php實(shí)現(xiàn)讀取文件頭判斷文件類(lèi)型,支持圖片、rar、exe等后綴進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08