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