关于php:4个提高脚本性能的PHP技巧

31次阅读

共计 1693 个字符,预计需要花费 5 分钟才能阅读完成。

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

正文完
 0