通常,我应用显著的惯例PHP函数编写代码来解决相应的问题。然而对于其中的一些问题,我遇到了一些代替解决方案,这些解决方案特地进步了性能。
在本文中,我想介绍一些代替计划。如果您正在寻找可能缩小生产中执行工夫的可能性,这将很有用。让咱们看看,哪种PHP办法可能会被性能更高的办法所取代,以及是否存在老本或折衷的问题。
1.删除反复项
您有一个蕴含反复项的大型数组,并且心愿删除它们,使其仅具备惟一值的数组。
惯例
array_unique($array);
代替
array_keys(array_flip($array));
体现
我创立了一个数组,其中蕴含超过400万个元素和300万个反复项。这是最佳后果:
办法 | 执行工夫解决工夫 |
---|---|
array_unique | 787.31毫秒 |
array_keys array_flip | 434.03毫秒 |
代替办法在此测量中快1.8倍(44.87%)。均匀而言,速度进步了约1.5倍(30%)。衡量:这仅实用于简略的一维数组,因为array_flip
用值替换了键。
2.获取随机数组记录
您有一个很大的数组,想要从中抉择一个随机值。
惯例
array_rand($array);
代替
$array[mt_rand(0, count($array) - 1)];
体现
我创立了一个蕴含500万个元素的数组。这是最佳后果:
办法 | 执行工夫解决工夫 |
---|---|
array_rand | 25.99微秒 |
mt_rand | 0.95微秒 |
代替办法是此测量速度快27.3倍(96.33%)。均匀而言,速度进步了约8倍(87%)。这个后果特地令人诧异,因为mt_rand
Mersenne Twister随机数生成器的实现也是如此,并且自PHP 7.1起,外部随机化算法已更改为应用完全相同的算法。
3.测试字母数字字符
您有一个字符串,要测试,如果它仅蕴含字母数字字符。
惯例
preg_match('/^[a-zA-Z0-9]+$/', $string);
代替
ctype_alnum($string);
体现
我创立了一个蕴含100k以上字母数字和非字母数字字符串的数组。这是最佳后果:
办法 | 执行工夫解决工夫 |
---|---|
preg_match | 15.39毫秒 |
ctype_alnum | 2.06毫秒 |
在此测量中,代替办法快了7.5倍(86.59%)。均匀而言,速度进步了约4倍(76%)。能够将雷同的内容利用于ctype_alpha()
(查看字母字符)和ctype_digit()
(查看数字字符)。
4.替换子字符串
您有一个字符串,想要用另一个子字符串替换它的一部分。
惯例
str_replace('a', 'b', $string);
代替
strtr($string, 'a', 'b');
体现
我创立了一个蕴含500万个随机字符串的数组。这是最佳后果:
办法 | 执行工夫解决工夫 |
---|---|
str_replace | 676.59毫秒 |
strtr | 305.59毫秒 |
另一种办法是2.2倍(54.83%)在该测量更快。均匀而言,速度进步了约2倍(51%)。
其余性能改良
这是我整合到我的编码约定中的一些其余要点,发现它们能够略微改善性能(如果实用):
- 首选JSON比XML
- 在循环之前而不是在循环的每个迭代中申明变量
- 防止在循环头中进行函数调用(在每次迭代中均
for ($i=0; $i<count($array); $i)
在count()
get中调用) - 重置内存耗费变量
- 优先选择
select
语句而不是多个if
语句 - 优先于
require / include
而不是require_once / include_once
(确保适当的操作码缓存)
最初几句话:我晓得无关过早优化的探讨。我批准生产中的性能取决于瓶颈,例如数据库查问,在解决性能时应重点关注。然而我认为,如果有更快的代替办法,例如在正则表达式更易于解决和保护的状况下,为什么不应用它们呢?
最初
咱们曾经看到,即便应用以后的PHP 7.4(曾经比以前的PHP版本快很多),也能够通过其余办法来进步脚本性能。如果您想亲自验证本文中提供的数据,我创立了一个蕴含所有测试的存储库:
devmount / faster-php测试进步 PHP 脚本性能的不同办法
我应用了Bart van Hoekelen的杰出工具来掂量执行工夫。