PHP中數組插入資料通常有這麼多種:
$arr = array(‘apple’, ’banana’);
$arr = array(); $arr[] = ‘apple’; $arr[] = ‘banana’;
$arr = array(‘apple’); array_push($arr, ‘banana’, ‘orange’);
在專案中,我們大部分情況都是先從資料庫中取得數據,然後轉換成數組形式,而對於第一種情況,在定義數組的時候直接賦值往往只適合資料量很小,而且是已知的情況,所以就不存在什麼程式碼最佳化了,我們主要講第二種和第三種。
我們使用php 7.2
來測試,並且沒有做任何配置上的最佳化。測試方法:定義一個數組,分別用第二種和第三種方式插入10萬筆記錄,程式碼大致如下:
convert
函數用來查看記憶體佔用情況,運行結果如下:
#透過多次執行上述程式碼,可以發現直接使用陣列變數賦值耗時在0.0045
左右,而使用array_push
的方式耗時在0.006
左右,消耗的記憶體都是一樣的,因為都是10萬筆記錄。
比較兩種方法,發現方法二確實比呼叫array_push
快,因為在每次循環時函數呼叫需要消耗一些時間,但僅僅看上面的測試,並不覺得第二種方法比第三種方法快多少,完全可以忽略的。
的確,這種優化在絕大多數應用中和沒優化沒啥區別,但是當應用達到瓶頸的時候,每一處不起眼的優化可能都會使性能提高不少,況且我們的測試中數組的結構很簡單,真實項目中資料型態不是這麼單一,可能還是嵌套的數組,數組的大小可能不只10萬。
我們再來看看兩者的差異,array_push()
是函數調用,另一個不是,這就是說了,從程式碼量上看兩者也是一樣的,從數組結構上看,測試中我們都沒有使用索引,預設都是從0開始,如果要使用key => value
形式插入資料時,array_push()
就不太好處理了,這時使用法二就很方便:$array1[$key] => $x
。
前面都是說array_push()
怎麼不好,但有時候array_push
還是很好用的。例如我們要一次插入多個元素時,就可以這樣使用:
$arr = array(‘a’, ’b’); array_push($arr, ‘c’, ‘d’); // $arr = array(‘a’, ’b’, ‘c’, ‘d’);
透過上面對比可見,PHP中數組插值的方法有很多,雖然每種方法差不多,但了解每種方法何時使用還是有必要的。
相關課程:PHP影片教學
#以上是PHP程式碼最佳化之array_push的詳細內容。更多資訊請關注PHP中文網其他相關文章!