PHP 비디오 튜토리얼
" 1. 중복 항목 제거array_unique($array);
array_keys(array_flip($array));
array_unique | 787.31毫秒 |
array_keys array_flip | 434.03毫秒 |
替代方法在此测量中快1.8倍(44.87%)。平均而言,速度提高了约1.5倍(30%)。权衡:这仅适用于简单的一维数组,因为array_flip
用值替换了键。
您有一个很大的数组,想要从中选择一个随机值。
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起,内部随机化算法已更改为使用完全相同的算法。
您有一个字符串,要测试,如果它仅包含字母数字字符。
preg_match('/^[a-zA-Z0-9]+$/', $string);
ctype_alnum($string);
我创建了一个包含100k以上字母数字和非字母数字字符串的数组。这是最佳结果:
方法 | 执行时间处理时间 |
---|---|
preg_match | 15.39毫秒 |
ctype_alnum | array_keys array_flip |
array_flip
은 키를 값으로 대체하므로 이는 단순한 1차원 배열에서만 작동합니다. str_replace('a', 'b', $string);
strtr($string, 'a', 'b');
array_rand
🎜🎜25.99 마이크로초🎜🎜🎜🎜mt_rand
🎜 🎜 0.95 마이크로초🎜🎜🎜🎜🎜대안은 🎜27.3배 빠른🎜(96.33%) 측정입니다. 평균적으로 속도 향상은 약 8배(87%)입니다. 이 결과는 mt_rand
Mersenne Twister 난수 생성기의 구현도 마찬가지이고 PHP 7.1부터 내부 무작위 알고리즘이 정확히 동일한 알고리즘을 사용하도록 변경되었기 때문에 특히 놀랍습니다. preg_match
🎜🎜15.39 ms🎜🎜🎜🎜ctype_alnum
🎜 🎜 2.06밀리초🎜🎜🎜🎜在此测量中,替代方法快了7.5倍(86.59%)。平均而言,速度提高了约4倍(76%)。可以将相同的内容应用于ctype_alpha()
(检查字母字符)和ctype_digit()
(检查数字字符)。
您有一个字符串,想要用另一个子字符串替换它的一部分。
str_replace('a', 'b', $string);
strtr($string, 'a', 'b');
我创建了一个包含500万个随机字符串的数组。这是最佳结果:
方法 | 执行时间处理时间 |
---|---|
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
위 내용은 스크립트 성능을 향상시키는 4가지 PHP 팁 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!