Я в замешательстве по поводу скорости sizeof ($ x) против $ x в цикле. Этот сайт: phpbench.com утверждает, что цикл sizeof ($ x) без предварительного calc -count () ТЫСЯЧИ процентов медленнее, чем с pre calc count (). Итак, я сделал тест, как показано ниже, но я не уверен, что это правильный способ проверить его. Результаты показывают, что время почти одинаково для каждой функции. Так что я не понимаю, как это будет сильно отличаться от сайта phpbench.
Таким образом, я хотел бы знать определенный ответ, если функция a (с sizeof ($ unset)) действительно значительно медленнее, чем функция b (с предварительно вычисленным значением $ unset). Я думаю, что теперь значения / функции хранятся в памяти, поэтому sizeof ($ x) может быть быстрее, чем на серверах несколько лет назад?
<?php
$v=0;
function a()
{
//sizeof
$unset=array('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o');
for($i=0;$i<sizeof($unset);$i++) {$v=$v+1;}
return;
}
function b()
{
//pre calculated
$unset=array('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o');
for($i=0;$i<15;$i++) {$v=$v+1;}
return;
}
function benchmark($func)
{
$start = microtime(true);
for ($i = 0; $i < 500000; $i++) {
$func();
}
$end = microtime(true);
$time = $end - $start;
echo $func . " time: " . sprintf('%.4f', $time) . PHP_EOL.'<br>';
}
benchmark('a'); // sizeof
benchmark('b'); // count
?>
По моим оценкам sizeof()
а также count()
выполнить примерно то же самое, однако, чтобы увеличить производительность самого цикла, вы можете сделать следующее:
for($i=0, $c=sizeof($unset);$i<$c;$i++){
$v=$v+1;
}
Это должно дать ему повышение производительности, потому что он не должен оценивать функцию в каждом цикле цикла.
Система, которую я использовал Вот со следующим кодом:
$b = new \Benchmark(10000);
$b->register('sizeof', function(){
$unset=array('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o');
for($i=0;$i<sizeof($unset);$i++) {$v=$v+1;}
});
$b->register('count', function(){
$unset=array('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o');
for($i=0;$i<count($unset);$i++) {$v=$v+1;}
});
$b->register('count 2', function(){
$unset=array('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o');
for($i=0, $c=count($unset);$i<$c;$i++) {$v=$v+1;}
});
$b->register('preset', function(){
$unset=array('a','b','c','d','e','f','g','h','i','j','k','l','m','n','o');
for($i=0;$i<15;$i++) {$v=$v+1;}
});
print_r($b->start());
С этим в качестве результатов:
Array
(
[stats] => Array
(
[phpversion] => 7.1.1
[itterations] => 40000
[duration] => 0.1180682182
[fastest] => preset
[slowest] => sizeof
)
[results] => Array
(
[0] => Array
(
[name] => preset
[time] => 0.0265829563
[average] => 0.0000026583
[speed] => 19.73%
)
[1] => Array
(
[name] => count 2
[time] => 0.0271441936
[average] => 0.0000027144
[speed] => 18.04%
)
[2] => Array
(
[name] => count
[time] => 0.0312242508
[average] => 0.0000031224
[speed] => 5.71%
)
[3] => Array
(
[name] => sizeof
[time] => 0.0331168175
[average] => 0.0000033117
[speed] => 0.00%
)
)
)
Других решений пока нет …