Typically, I write code using obvious regular PHP functions to solve the corresponding problem. But for some of these problems I've come across some alternative solutions that specifically improved performance.
Recommended: "PHP Video Tutorial"
In this article, I would like to introduce some alternatives. This is useful if you are looking for possibilities to reduce execution time in production. Let's see which PHP method might be replaced by a more performant method and whether there are any cost or trade-off issues.
You have a large array containing duplicates and want to remove them so that it only has an array of unique values.
array_unique($array);
array_keys(array_flip($array));
I created An array with over 4 million elements and 3 million duplicates. This is the best result:
Method | Execution time Processing time |
---|---|
array_unique | 787.31 ms |
array_keys array_flip | 434.03 ms |
The alternative method is 1.8 times (44.87%) faster in this measurement. On average, the speedup is about 1.5x (30%). Trade-off: This only works for simple 1D arrays because array_flip
replaces keys with values.
You have a large array and want to select a random value from it.
array_rand($array);
$array[mt_rand(0, count($array) - 1)];
I created An array containing 5 million elements. This is the best result:
Method | Execution time Processing time |
---|---|
array_rand | 25.99 microseconds |
##mt_rand
| 0.95 microsecond
27.3 times faster (96.33%). On average, the speedup is about 8x (87%). This result is particularly surprising because so is the implementation of the mt_randMersenne Twister random number generator, and since PHP 7.1 the internal randomization algorithm has been changed to use the exact same algorithm.
preg_match('/^[a-zA-Z0-9]+$/', $string);
ctype_alnum($string);
Execution time Processing time | |
---|---|
preg_match
| 15.39 ms|
2.06 ms |
方法 | 执行时间处理时间 |
---|---|
str_replace |
676.59毫秒 |
strtr |
305.59毫秒 |
另一种方法是2.2倍(54.83%)在该测量更快。平均而言,速度提高了约2倍(51%)。
这是我整合到我的编码约定中的一些其他要点,发现它们可以稍微改善性能(如果适用):
for ($i=0; $i<count($array); $i)
在count()
get中调用)最后几句话:我知道有关过早优化的讨论。我同意生产中的性能取决于瓶颈,例如数据库查询,在处理性能时应重点关注。但是我认为,如果有更快的替代方法,例如在正则表达式更易于处理和维护的情况下,为什么不使用它们呢?
我们已经看到,即使使用当前的PHP 7.4(已经比以前的PHP版本快很多),也可以通过其他方法来提高脚本性能。如果您想亲自验证本文中提供的数据,我创建了一个包含所有测试的存储库:
测试提高 PHP 脚本性能的不同方法
我使用了Bart van Hoekelen的出色工具来衡量执行时间。
转载自:Andreas
The above is the detailed content of Share 4 PHP tips to improve script performance. For more information, please follow other related articles on the PHP Chinese website!