⊗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štinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Մենք օգտագործում ենք cookie-ներ կայքի աշխատանքի, վերլուծության և անհատականացման համար։ Տվյալների մշակումը կատարվում է համաձայն Գաղտնիության քաղաքականության։
ընդունել բոլորը կարգավորել մերժել