$arr = array(‘a(chǎn)pple’, ’banana’);使用數(shù)組變量操作
$arr = array();$arr[] = ‘a(chǎn)pple’;$arr[] = ‘banana’;使用array_push()插入
$arr = array(‘a(chǎn)pple’);array_push($arr, ‘banana’, ‘orange’);
在項目中,我們大部分情況都是先從數(shù)據(jù)庫中獲取數(shù)據(jù),然后轉(zhuǎn)成數(shù)組形式,而對于第一種情況,在定義數(shù)組的時候直接賦值往往只適合數(shù)據(jù)量很小,而且是已知的情況,所以就不存在什么代碼優(yōu)化了,我們主要講第二種和第三種。
性能比較我們使用php 7.2來測試,并且沒有做任何配置上的優(yōu)化。測試方法:定義一個數(shù)組,分別用第二種和第三種方式插入10萬條記錄,代碼大致如下:
convert函數(shù)用來查看內(nèi)存占用情況,運行結(jié)果如下:
通過多次運行上述代碼,可以發(fā)現(xiàn)直接使用數(shù)組變量賦值耗時在0.0045左右,而使用array_push的方式耗時在0.006左右,消耗的內(nèi)存都是一樣的,因為都是10萬條記錄。
對比兩種方法,發(fā)現(xiàn)方法二確實比調(diào)用array_push快,因為在每次循環(huán)時函數(shù)調(diào)用需要消耗一些時間,但僅僅看上面的測試,并不覺得第二種方法比第三種方法快多少,完全可以忽略不計的。
的確,這種優(yōu)化在絕大多數(shù)應(yīng)用中和沒優(yōu)化沒啥區(qū)別,但是當(dāng)應(yīng)用達(dá)到瓶頸的時候,每一處不起眼的優(yōu)化可能都會使性能提高不少,況且我們的測試中數(shù)組的結(jié)構(gòu)很簡單,真實項目中數(shù)據(jù)類型不是這么單一,可能還是嵌套的數(shù)組,數(shù)組的大小可能也不止10萬。
我們再來看看兩者的差異,array_push()是函數(shù)調(diào)用,另一個不是,這就是說了,從代碼量上看兩者也是一樣的,從數(shù)組結(jié)構(gòu)上看,測試中我們都沒有使用索引,默認(rèn)都是從0開始,如果要使用key = html' target='_blank'>value形式插入數(shù)據(jù)時,array_push()就不是很好處理了,這時使用法二就很方便:$array1[$key] = $x。
前面都是說array_push()怎么不好,但有時候array_push還是很好用的。比如我們要一次插入多個元素時,就可以這樣使用:
$arr = array(‘a(chǎn)’, ’b’);array_push($arr, ‘c’, ‘d’);// $arr = array(‘a(chǎn)’, ’b’, ‘c’, ‘d’);
通過上面對比可見,PHP中數(shù)組插值的方法有很多,雖然每種方法差不多,但了解每一種方法何時使用還是很有必要的。
相關(guān)課程:PHP視頻教程
以上就是PHP代碼優(yōu)化之a(chǎn)rray_push的詳細(xì)內(nèi)容,PHP教程
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。
|
新聞熱點
疑難解答
圖片精選