⊗ppSpOtAU 82 of 83 menu

PHP හි අනවශ්‍ය අරාවන් ප්‍රශස්ත කිරීම

තැනක් හිටියොත්, යම් ක්‍රමලේඛකයෙකුට කර්තව්‍යයක් ඇත 1 සිට 100000000 දක්වා පූර්ණ සංඛ්‍යාවල එකතුව සොයා ගැනීම.

අපගේ ක්‍රමලේඛකයා මෙම කාර්යය සඳහා සරල විසඳුමක් ලිව්වේ, මෙසේය:

<?php echo array_sum(range(1, 100000000)); ?>

සුන්දර විසඳුමක්, නේද? එක පේලියකින් හා සියල්ල එසේම. නමුත් එය ක්‍රියාත්මක නොවේ! උත්සාහ කරන්න මෙම කේතය ක්‍රියාත්මක කරන්න, එය තිරය මත ප්‍රදර්ශනය කරයි දෝෂයක් ඔබ ඉල්ලා සිටියේ බව අනවශ්‍ය මතකයක්.

හ්ම්, 100000000 එතරම් විශාල නොවේද? නැතහොත් විශාලද? අපි ගණන් කරමු. ශ්‍රිතය range 100000000 සංඛ්‍යා සහිත අරාවක් සාදයි. PHP සංඛ්‍යාවක් සඳහා 2 බයිට් වෙන් කරයි - එවිට අපගේ අරාව ගබඩා කිරීමට අවශ්‍ය වේ 200000000 බයිට්, එනම් ආසන්න වශයෙන් 200 මෙගාබයිට් මතකය.

නමුත් ඇත්ත වශයෙන්ම, වැඩි මතකයක් අවශ්‍ය වේ PHP හි අරාවක් ගබඩා කිරීමේදී ඉතා බොහෝ දුරට වැඩි පිරිවැය හේතුවෙන්. උදාහරණයක් ලෙස, මගේ දෝෂ පණිවුඩයේ දක්වා ඇත්තේ, මම 4294967304 වෙන් කිරීමට උත්සාහ කරන බව බයිට් - ආසන්න වශයෙන් 4 ගිගාබයිට්!

දෝෂය ඇති වන්නේ මන්දැයි දැන් පැහැදිලිය - අපි අවසර දී ඇති මතක සීමාව ඉක්මවා ගියෙමු.

අපගේ ස්ක්‍රිප්ට් එක වෙනත් එකකට නැවත ලිවීම එතරම් අපහසු නැත, ප්‍රායෝගිකව මතකය භාවිතා නොකරන:

<?php $sum = 0; for ($i = 1; $i <= 100000000; $i++) { $sum += $i; } echo $sum; ?>

තවද ගණිතමය විසඳුම භාවිතා කිරීම වඩා හොඳය:

<?php $n = 1000000; $sum = $n * ($n + 1) / 2; echo $sum; ?>

යම් ක්‍රමලේඛකයෙකුට කර්තව්‍යයක් තිබුණි දී ඇති සංඛ්‍යාවක කාරකය සොයා ගැනීම. ඔහු එය පහත පරිදි විසඳුවේය:

<?php $n = 100; echo array_product(range(1, $n)); ?>

මෙම කේතයේ ඇති දෝෂය පැහැදිලි කරන්න. නැවත සකස් කරන්න වඩාත් ප්‍රශස්ත කේතයක්.

යම් ක්‍රමලේඛකයෙකුට කර්තව්‍යයක් තිබුණි අංක සංඛ්‍යාව සොයා ගැනීම, සියලු පූර්ණ සංඛ්‍යා 1 සිට 1000000 දක්වා ලිවීමට භාවිතා කළ හැකිය. ඔහු එය පහත පරිදි විසඳුවේය:

<?php echo strlen(implode('', range(1, 1000000))); ?>

මෙම කේතයේ ඇති දෝෂය පැහැදිලි කරන්න. නැවත සකස් කරන්න වඩාත් ප්‍රශස්ත කේතයක්.

යම් ක්‍රමලේඛකයෙකුට කර්තව්‍යයක් තිබුණි ඉතිරියකින් තොරව 7 න් බෙදිය හැකි සංඛ්‍යා ප්‍රමාණය සොයා ගැනීම, දී ඇති පරාසයක පිහිටා ඇත. ඔහු එය පහත පරිදි විසඳුවේය:

<?php $arr = []; for ($i = 0; $i <= 1000; $i++) { if ($i % 7 == 0) { $arr[] = $i; } } echo count($arr); ?>

මෙම කේතයේ ඇති දෝෂය පැහැදිලි කරන්න. නැවත සකස් කරන්න වඩාත් ප්‍රශස්ත කේතයක්.

යම් ක්‍රමලේඛකයෙකුට කර්තව්‍යයක් තිබුණි සංඛ්‍යාවක බෙදුම්කරුවන්ගේ එකතුව සොයා ගැනීම. ඔහු එය පහත පරිදි විසඳුවේය:

<?php $num = 320; $divs = []; for ($i = 0; $i <= $num; $i++) { if ($num % $i == 0) { $divs[] = $i; } } echo array_sum($divs); ?>

මෙම කේතයේ ඇති දෝෂය පැහැදිලි කරන්න. නැවත සකස් කරන්න වඩාත් ප්‍රශස්ත කේතයක්.

සිංහල
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
අපි වෙබ් අඩවිය ක්‍රියාත්මක කිරීම, විශ්ලේෂණය සහ පුද්ගලීකරණය සඳහා කුකී භාවිතා කරමු. දත්ත සැකසීම සිදුකරනු ලබන්නේ ගෝපනීයතා ප්‍රතිපත්තිය අනුව ය.
සියල්ල පිළිගන්න කොන්දේසි ප්‍රතික්ෂේප කරන්න