您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)php中如何提高腳本性能的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
通常,我使用明顯的常規(guī)PHP函數(shù)編寫代碼來解決相應(yīng)的問題。但是對于其中的一些問題,我遇到了一些替代解決方案,這些解決方案特別提高了性能。
在本文中,我想介紹一些替代方案。如果您正在尋找可能減少生產(chǎn)中執(zhí)行時間的可能性,這將很有用。讓我們看看,哪種PHP方法可能會被性能更高的方法所取代,以及是否存在成本或折衷的問題。
1.刪除重復(fù)項(xiàng)
您有一個包含重復(fù)項(xiàng)的大型數(shù)組,并且希望刪除它們,使其僅具有唯一值的數(shù)組。
常規(guī)
array_unique($array);
替代
array_keys(array_flip($array));
表現(xiàn)
我創(chuàng)建了一個數(shù)組,其中包含超過400萬個元素和300萬個重復(fù)項(xiàng)。這是最佳結(jié)果:
方法 | 執(zhí)行時間處理時間 |
---|---|
array_unique | 787.31毫秒 |
array_keys array_flip | 434.03毫秒 |
替代方法在此測量中快 1.8倍 (44.87%)。平均而言,速度提高了約1.5倍(30%)。權(quán)衡:這僅適用于簡單的一維數(shù)組,因?yàn)?array_flip
用值替換了鍵。
2.獲取隨機(jī)數(shù)組記錄
您有一個很大的數(shù)組,想要從中選擇一個隨機(jī)值。
常規(guī)
array_rand($array);
替代
$array[mt_rand(0, count($array) - 1)];
表現(xiàn)
我創(chuàng)建了一個包含500萬個元素的數(shù)組。這是最佳結(jié)果:
方法 | 執(zhí)行時間處理時間 |
---|---|
array_rand | 25.99微秒 |
mt_rand | 0.95微秒 |
替代方法是此測量速度快 27.3倍 (96.33%)。平均而言,速度提高了約8倍(87%)。這個結(jié)果特別令人驚訝,因?yàn)?mt_rand
Mersenne Twister隨機(jī)數(shù)生成器的實(shí)現(xiàn)也是如此,并且自PHP 7.1起,內(nèi)部隨機(jī)化算法已更改為使用完全相同的算法。
3.測試字母數(shù)字字符
您有一個字符串,要測試,如果它僅包含字母數(shù)字字符。
常規(guī)
preg_match('/^[a-zA-Z0-9]+$/', $string);
替代
ctype_alnum($string);
表現(xiàn)
我創(chuàng)建了一個包含100k以上字母數(shù)字和非字母數(shù)字字符串的數(shù)組。這是最佳結(jié)果:
方法 | 執(zhí)行時間處理時間 |
---|---|
preg_match | 15.39毫秒 |
ctype_alnum | 2.06毫秒 |
在此測量中,替代方法快了 7.5倍 (86.59%)。平均而言,速度提高了約4倍(76%)??梢詫⑾嗤膬?nèi)容應(yīng)用于 ctype_alpha()
(檢查字母字符)和 ctype_digit()
(檢查數(shù)字字符)。
4.替換子字符串
您有一個字符串,想要用另一個子字符串替換它的一部分。
常規(guī)
str_replace('a', 'b', $string);
替代
strtr($string, 'a', 'b');
表現(xiàn)
我創(chuàng)建了一個包含500萬個隨機(jī)字符串的數(shù)組。這是最佳結(jié)果:
方法 | 執(zhí)行時間處理時間 |
---|---|
str_replace | 676.59毫秒 |
strtr | 305.59毫秒 |
另一種方法是 2.2倍 (54.83%)在該測量更快。平均而言,速度提高了約2倍(51%)。
其他性能改進(jìn)
這是我整合到我的編碼約定中的一些其他要點(diǎn),發(fā)現(xiàn)它們可以稍微改善性能(如果適用):
for ($i=0; $i<count($array); $i)
在 count() get
中調(diào)用) select
語句而不是多個 if
語句 require / include
而不是 require_once / include_once
(確保適當(dāng)?shù)牟僮鞔a緩存)最后幾句話:我知道有關(guān)過早優(yōu)化的討論。我同意生產(chǎn)中的性能取決于瓶頸,例如數(shù)據(jù)庫查詢,在處理性能時應(yīng)重點(diǎn)關(guān)注。但是我認(rèn)為,如果有更快的替代方法,例如在正則表達(dá)式更易于處理和維護(hù)的情況下,為什么不使用它們呢?
最后
我們已經(jīng)看到,即使使用當(dāng)前的PHP 7.4(已經(jīng)比以前的PHP版本快很多),也可以通過其他方法來提高腳本性能。如果您想親自驗(yàn)證本文中提供的數(shù)據(jù),我創(chuàng)建了一個包含所有測試的存儲庫:
devmount/faster-php
測試提高 PHP 腳本性能的不同方法
我使用了Bart van Hoekelen的出色工具來衡量執(zhí)行時間。
感謝各位的閱讀!關(guān)于php中如何提高腳本性能就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。