Оптимизация на циклични операции в PHP
Дори и лека операция, многократно повтаряна в цикъл, може да отнеме много ресурси.
Нека разгледаме пример. Да предположим, че имаме даден масив:
<?php
$arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
?>
Нека намерим средната стойност на елементите на този масив. За целта трябва да намерим сумата на елементите и да я разделим на броя им. Да предположим, че някой програмист вече е решил тази задача по следния начин:
<?php
$sum = 0;
foreach ($arr as $elem) {
$sum += $elem / count($arr);
}
echo $sum;
?>
Нека разгледаме проблемите на това решение. Технически кодът работи правилно и дава верен отговор. Работата е там, че математически е коректно както да разделим цялата сума на броя, така и да разделим всяко от събираемите на броя.
Възниква обаче друг проблем. Работата е там, че ще извършваме деление толкова пъти, колкото елемента има в нашия масив. И се оказва, че правим голям брой излишни операции, тъй като делението можеше да се извърши накрая - веднъж, като се раздели цялата намерена сума.
Нека оптимизираме нашия код:
<?php
$sum = 0;
foreach ($arr as $elem) {
$sum += $elem;
}
echo $sum / count($arr);
?>
Оптимизирайте дадения по-долу код:
<?php
for ($i = 1; $i <= 31; $i++) {
if ($i === date('d')) {
echo "<b>$i</b><br>";
}
if ($i !== date('d')) {
echo "$i<br>";
}
}
?>