⊗ppSpOtRHO 73 of 83 menu

Βελτιστοποίηση Επανάληψης Βαρέων Λειτουργιών σε 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; } ?>
Ελληνικά
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Χρησιμοποιούμε cookie για τη λειτουργία του ιστότοπου, την ανάλυση και την εξατομίκευση. Η επεξεργασία των δεδομένων γίνεται σύμφωνα με την Πολιτική Απορρήτου.
αποδοχή όλων ρύθμιση απόρριψη