Оптимизација на циклични операции во PHP
Дури и лесна операција, повторена многу пати во циклус, може да одземе многу ресурси.
Да го погледнеме примерот. Нека ни е даден некој array:
<?php
$arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
?>
Да го најдеме просекот на елементите на овој array. За тоа треба да се најде збирот на елементите и да се подели со нивниот број. Нека некој програмер веќе ја решил оваа задача на следниов начин:
<?php
$sum = 0;
foreach ($arr as $elem) {
$sum += $elem / count($arr);
}
echo $sum;
?>
Да ги разгледаме проблемите на ова решение. Технички, кодот работи правилно и дава точен одговор. Работата е што математички е точно и да се подели целиот збир со бројот на елементи, и да се подели секој од поединечните елементи со бројот на елементи.
Сепак, се појавува друг проблем. Работата е што ние ќе ја извршуваме операцијата делење онолку пати колку што има елементи во нашиот array. И излегува дека правиме голем број на непотребни операции, бидејќи делењето можеше да се изврши на крајот - само еднаш, делејќи го целиот пронајден збир.
Да го оптимизираме нашиот код:
<?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>";
}
}
?>