ריבוי משימות
ריבוי משימות (באנגלית: Multitasking) הוא היכולת של מחשב לבצע מספר משימות במקביל. כאשר למחשב יש מעבד יחיד, רק משימה אחת יכולה לרוץ עליו בכל פרק זמן נתון, אולם אפשר לקבל הדמיה של הרצת מספר משימות במקביל על ידי מעבר מהיר בין משימות שונות. המעבר הזה נקרא גם שיתוף זמן (time sharing).
המעבר בין הרצת משימות שונות נקרא החלפת הקשר, מכיוון שבו עוברים מהסביבה (ההקשר) של משימה אחת לזו של משימה אחרת. למשימות קוראים (במערכות שונות) תהליכים, תהליכונים, או משימות.
מוסדר
[עריכת קוד מקור | עריכה]ריבוי משימות מוסדר[1] (Preemptive Multitasking) הוא המימוש המקובל לריבוי משימות במערכות הפעלה. סדרן מרכזי (בדרך כלל חלק ממערכת ההפעלה) אחראי להקצות את המעבדים לתהליכים. הסדרן יכול להפריע (preempt) לתהליך אם עבר זמנו.
שיתופי
[עריכת קוד מקור | עריכה]ריבוי משימות שיתופי[2] (Cooperative Multitasking) הוא ריבוי משימות שממומש על ידי התהליכים עצמם ללא כפייה של מערכת ההפעלה או סדרן מרכזי אחר. כאשר תהליך סיים לעבוד עם המעבד הוא קורא לפעולת yield (מאנגלית: ויתור) שמעבירה את הביצוע לתהליך הבא.
המימוש הזה פשוט יותר אולם תהליך סורר אחד יכול לתקוע את כל המערכת. מימוש זה של ריבוי משימות היה בשימוש ב-Microsoft Windows 3.x וב-MacOS, לדוגמה.
חלוקת המשאבים
[עריכת קוד מקור | עריכה]רכיב התוכנה שאחראי על חלוקת הזמן נקרא סדרן תוכניות. חלוקת הזמן לא בהכרח שווה ויכולה להתבסס על היוריסטיקות שונות. היוריסטיקה אפשרית היא לתת העדפה (יותר זמן עיבוד) לתהליכים גדולים יותר, לדוגמה.
בעת חלוקת המשאבים יש סכנת הרעבה של תהליכים, כלומר מצב שבו תהליך בעל עדיפות נמוכה לא יקבל את זמן העיבוד או הגישה למשאב הנצרך לו גם לאחר זמן. לשם כך ניתן להשתמש במנגנון "הזדקנות" שבו אם עבר זמן רב מאז שתהליך קיבל זמן עיבוד או גישה למשאב, הוא יקבל עדיפות גבוהה יותר.
ראו גם
[עריכת קוד מקור | עריכה]קישורים חיצוניים
[עריכת קוד מקור | עריכה]- אוהד ברזילי, על ביצוע של משימות מרובות במקביל, ספטמבר 2011 - סרטון הסבר אינטואיטיבי וקצר בווידאו בלוג העברי - אינטרטנט
- ריבוי משימות, באתר אנציקלופדיה בריטניקה (באנגלית)
הערות שוליים
[עריכת קוד מקור | עריכה]