Βελτιστοποίηση Επανάληψης Βαρέων Λειτουργιών σε PHP
Στο προηγούμενο μάθημα, οι επαναλαμβανόμενες κλήσεις συναρτήσεων στην πραγματικότητα απαιτούν πολύ λίγο χρόνο και η βελτιστοποίησή μας θα εξοικονομήσει όχι πολύ. Ωστόσο, όλα θα είναι πολύ χειρότερα αν κάνουμε πολλές φορές κλήση μιας "βαρείας" συνάρτησης, η οποία εκτελείται για αρκετά μεγάλο χρονικό διάστημα.
Ας υποθέσουμε, για παράδειγμα, ότι έχουμε μια συνάρτηση που βρίσκει τους διαιρέτες ενός αριθμού:
<?php
function getDivisors($num) {
$result = [];
for ($i = 1; $i <= $num; $i++) {
if ($num % $i == 0) {
$result[] = $i;
}
}
return $result;
}
?>
Προφανώς, αυτή η συνάρτηση είναι αρκετά "βαρεία". Επομένως, κακή ιδέα θα ήταν να γράψουμε τον ακόλουθο κώδικα:
<?php
$num = 123456;
if (array_sum(getDivisors($num)) >= 10 and array_sum(getDivisors($num)) <= 100) {
} else {
}
?>
Καλύτερα, φυσικά, είναι να εκτελέσουμε τη "βαρεία" λειτουργία μία φορά και να αποθηκεύσουμε το αποτέλεσμα σε μια μεταβλητή, και στη συνέχεια να χρησιμοποιήσουμε αυτή τη μεταβλητή στα απαραίτητα σημεία:
<?php
$num = 123456;
$sum = array_sum(getDivisors($num));
if ($sum >= 10 and $sum <= 100) {
} else {
}
?>
Βελτιστοποιήστε τον παρακάτω κώδικα:
<?php
$num = 1233456789;
if (getSumSquare($num) >= 10 and getSumSquare($num) <= 100) {
echo 'σωστό';
} else {
echo 'λάθος';
}
function getSumSquare($num) {
$digits = explode('', $num);
$sum = 0;
foreach ($digits as $digit) {
$sum += $digit * $digit;
}
return $digit;
}
?>