首頁 > 後端開發 > php教程 > PHP程式碼優化的方法介紹(圖文)

PHP程式碼優化的方法介紹(圖文)

不言
發布: 2023-04-05 18:32:02
轉載
3428 人瀏覽過

這篇文章帶給大家的內容是關於PHP程式碼優化的方法介紹(圖文),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

PHP中陣列插入資料通常有這麼多種:

定義的時候直接賦值

$arr = array(‘apple’, ’banana’);
登入後複製

使用陣列變數運算

$arr = array();
$arr[] = ‘apple’;
$arr[] = ‘banana’;
登入後複製

使用array_push()插入

$arr = array(‘apple’);
array_push($arr, ‘banana’, ‘orange’);
登入後複製

在專案中,我們大部分情況都是先從資料庫中取得數據,然後轉成數組形式,而對於第一種情況,在定義數組的時候直接賦值往往只適合資料量很小,而且是已知的情況,所以就不存在什麼程式碼優化了,我們主要講第二種和第三種。

關於array_push的使用,就不多介紹,自己看官方文件(https://secure.php.net/manual/en/function.array-push.php)。

效能比較

我們使用php 7.2來測試,並且沒有做任何配置上的最佳化。測試方法:定義一個數組,分別用第二種和第三種方式插入10萬筆記錄,程式碼大致如下:

PHP程式碼優化的方法介紹(圖文)

PHP程式碼優化的方法介紹(圖文)

convert函數用來查看記憶體佔用情況,運行結果如下:

PHP程式碼優化的方法介紹(圖文)

PHP程式碼優化的方法介紹(圖文)

#透過多次執行上述程式碼,可以發現直接使用數組變數賦值耗時在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程式碼優化的方法介紹(圖文)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板