26-08-2005, 06:04
|
|
|
|
חבר מתאריך: 20.06.03
הודעות: 5,616
|
|
שיטות אופטימיזציה - פרק 5
הערה: מאמר זה והבאים אחריו יסקרו שיטות שונות של אופטימיזציה, חלקן ברמת המהדר, וחלקן בשליטת המפתח.
אופטימיזציה של לולאות
אופטימיזציה ברמה הבינונית
זוהי אחת משיטות האופטימיזציה המועילות ביותר, מכיוון שכאן, כל קטע שאנו חוסכים - מוכפל בפעמים
בה הלולאה מבוצעת.
כל השיטות שדנו בהן עד כה, משתפרות פלאים בקוד הכלול בלולאות.
דוגמה פשוטה, ראינו בפרק המבוא בו אוחדו לולאות לכדי לולאה בודדת.
שיטה נוספת שהמהדר מבצע, אך ניתןו לבצע זאת גם בזמן כתיבת הקוד היא "הרמת קוד".
שיטה זן מכונה invariant code motion (תנועת קוד בלתי משתנה). שיטה זו למעשה היא העברת
קוד אל מחוץ ללולאה. הקוד אותו נעביר, הוא קוד שאינו משתנה בתוך הלולאה, ולכן ביצוע אותו
קטע קוד בכל איטרציה של הלולאה היא תהליך בזבזני.
דוגמה:
קוד PHP:
for (i=0 ; i < 100 ; i++) arr[i] = a + b;
במקרה זה, אם נעביר את ה"קוד שבלתי משתנה" אל מחוץ ללולאה, ניצור קוד, שיגרום למהדר
לחשב את הביטוי רק פעם אחת במקום 100 בדוגמה זו.
הנה פתרון אפשרי:
קוד PHP:
temp = a + b; for (i=0 ; i < 100 ; i++) arr[i] = temp;
פרקים קודמים:
אופטימיזציה של קוד - מבוא
שיטות אופטימיזציה - פרק 1
שיטות אופטימיזציה - פרק 2
שיטות אופטימיזציה - פרק 3+4
נערך לאחרונה ע"י fat fish בתאריך 27-08-2005 בשעה 19:21.
|