溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

php中如何提高腳本性能

發(fā)布時間:2020-08-19 09:58:13 來源:億速云 閱讀:143 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(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_unique787.31毫秒
array_keys array_flip434.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_rand25.99微秒
mt_rand0.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_match15.39毫秒
ctype_alnum2.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_replace676.59毫秒
strtr305.59毫秒

另一種方法是 2.2倍 (54.83%)在該測量更快。平均而言,速度提高了約2倍(51%)。

其他性能改進(jìn)

這是我整合到我的編碼約定中的一些其他要點(diǎn),發(fā)現(xiàn)它們可以稍微改善性能(如果適用):

  • 首選JSON比XML
  • 在循環(huán)之前而不是在循環(huán)的每個迭代中聲明變量
  • 避免在循環(huán)頭中進(jìn)行函數(shù)調(diào)用(在每次迭代中均
  • for ($i=0; $i<count($array); $i) count() get中調(diào)用)
  • 重置內(nèi)存消耗變量
  • 優(yōu)先選擇 select 語句而不是多個 if 語句
  • 優(yōu)先于 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é)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(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)容。

AI