Felesleges tömbhossz-számítás ciklusban PHP-ben
Legyen adott egy számtömb:
<?php
$arr = [1, 2, 3, 4, 5];
?>
Tegyük fel, hogy minden elemét
négyzetre akarjuk emelni. Vagyis ugyanaz a
$arr tömb maradjon, de a
számok négyzeteivel.
Ebben az esetben a foreach
ciklus nem megfelelő,
hanem egy sima for ciklusra van szükség
a tömbön,
így:
<?php
$arr = [1, 2, 3, 4, 5];
for ($i = 0; $i < count($arr); $i++) {
$arr[$i] = $arr[$i] * $arr[$i]; // minden tömbelemet megváltoztatunk
}
var_dump($arr);
?>
Mi a baj ezzel a kóddal? Az a probléma,
hogy a count($arr) feleslegesen
minden ciklusiterációban ki lesz számolva! De minek,
hiszen a tömb hossza a ciklusban nem változik, nem igaz?
Az optimalizáláshoz helyezzük a tömb hosszának kiszámítását egy külön változóba:
<?php
$arr = [1, 2, 3, 4, 5];
$len = count($arr); // optimalizálás
for ($i = 1; $i < $len; $i++) {
$arr[$i] = $arr[$i] * $arr[$i];
}
var_dump($arr);
?>
Optimalizálja az alábbi kódot:
<?php
$arr = [1, 2, 2, 4, 5];
for ($i = 1; $i < count($arr); $i++) {
if ($arr[$i - 1] === $arr[$i]) {
echo $arr[$i] . '<br>';
}
}
?>