Multitasking
Aus Lowlevel
Multitasking ist die Bezeichnung für das (nahezu) gleichzeitige Abarbeiten von Aufgaben (Tasks). Dies wird realisiert, indem blitzschnell zwischen mehreren Prozessen hin und her geschaltet wird und so jedem Prozess für eine bestimmte Zeit die CPU zur Verfügung gestellt wird.
Inhaltsverzeichnis |
Prinzip
Beim Multitasking wird ein Prozess ausgeführt, und dann nach einer bestimmten Zeit zum nächsten Prozess geschaltet. Dabei gibt es verschieden Sheduling - Algorithmen, also bestimmte Methoden, wie der nächste Task ausgewählt wird. Das einfachste hierbei ist das Round Robin. Es wird einfach eine Liste geführt, in der jeder Task angeführt ist. Ausgewählt wird dann immer der nächste Task in der Liste. Eine Idee ist es auch, mit Prioritäten zu arbeiten, das heißt, dass verschiedene Prozesse unterschiedlich gewichtet werden. (z.B. mehr Prozessorzeit bekommen, oder öfters aufgerufen werden) Beim Umschalten muss folgendes erledigt werden:
- ALLE Register speichern
- Rücksprungadresse speichern (damit man weiß, wo man das Programm fortführen muss)
- Stack wechseln
- Register des nächsten Prozesses wiederherstellen
- An die Rücksprungadresse des nächsten Prozesses springen.
Zwei Methoden
Dabei wird zwischen zwei Methoden unterschieden:
- Software - Multitasking
und
- Hardware - Multitasking
Software - Multitasking
Hierbei wird die Umschaltarbeit komplett vom Betriebsystem ausgeführt. Der Prozessor macht dabei nichts.
Hardware - Multitasking
Im Gegensatz zum Software-Multitasking, wird hier die meiste Arbeit vom Prozessor erledigt.
