通常,我应用显著的惯例 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 的杰出工具来掂量执行工夫。