⊗ppSpOtRHO 73 of 83 menu

Nehéz műveletek ismétlésének optimalizálása PHP-ban

Az előző leckében a függvények ismételt hívásai valójában nagyon kevés időt vesznek igénybe, és az optimalizációnk nem takarít meg nagyon sokat. Azonban mindennek sokkal rosszabb lesz a kimenetele, ha több alkalommal hívunk meg egy "nehéz" függvényt, amely elég hosszú ideig fut.

Tegyük fel például, hogy van egy függvényünk, amely megtalálja egy szám osztóit:

<?php function getDivisors($num) { $result = []; for ($i = 1; $i <= $num; $i++) { if ($num % $i == 0) { $result[] = $i; } } return $result; } ?>

Nyilvánvaló, hogy ez a függvény elég "nehéz". Ezért nem jó ötlet ilyen kódot írni:

<?php $num = 123456; if (array_sum(getDivisors($num)) >= 10 and array_sum(getDivisors($num)) <= 100) { } else { } ?>

Természetesen jobb, ha a "nehéz" műveletet egyszer hajtjuk végre, és az eredményt elmentjük egy változóba, majd ezt a változót használjuk a szükséges helyeken:

<?php $num = 123456; $sum = array_sum(getDivisors($num)); if ($sum >= 10 and $sum <= 100) { } else { } ?>

Optimalizálja az alábbi kódot:

<?php $num = 1233456789; if (getSumSquare($num) >= 10 and getSumSquare($num) <= 100) { echo 'helyes'; } else { echo 'helytelen'; } function getSumSquare($num) { $digits = explode('', $num); $sum = 0; foreach ($digits as $digit) { $sum += $digit * $digit; } return $digit; } ?>
Magyar
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
A weboldal működéséhez, elemzéshez és személyre szabáshoz sütiket használunk. Az adatfeldolgozás a Adatvédelmi irányelvek szerint történik.
összes elfogadása beállítás elutasítás