Erstes Leser-Schreiber-Problem
|
|
|
- Jan Fürst
- vor 8 Jahren
- Abrufe
Transkript
1 Erstes Leser-Schreiber-Problem Szenario: mehrere Leser und mehrere Schreiber gemeinsamer Datenbereich Schreiber haben exklusiven Zugriff Leser können parallel zugreifen (natürlich nur, wenn kein Schreiber zugreift) Implementierung mit Semaphoren Semaphor W regelt den exklusiven Zugriff mittels P(W) und V(W) W erlaubt durch einem Trick den parallelen Zugriff der Leser Nur der erste Leser ruft P(W) auf, der letzte dann V(W) Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 35
2 Beispiel int Readcount = 0; Semaphor W = 1, Mutex = 1; // Zugriff eines Leser-Threads: P(Mutex); Readcount++; if (Readcount == 1) P(W); V(Mutex); // Daten Lesen P(Mutex); Readcount--; if (Readcount == 0) V(W); V(Mutex); // Zugriff eines Schreiber-Threads: P(W); // Schreibe Daten V(W); Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 36
3 Ablaufbeispiel int Readcount = 0; Semaphor W = 1, Mutex = 1; // Zugriff eines Leser-Threads: 01 P(Mutex); 02 Readcount++; 03 if (Readcount == 1) P(W); 04 V(Mutex); 05 // Daten Lesen 06 P(Mutex); 07 Readcount--; 08 if (Readcount == 0) V(W); 09 V(Mutex); // Zugriff eines Schreiber-Threads: 10 P(W); 11 // Schreibe Daten 12 V(W); Mutex.z Mutex.L ReadCnt W.z W.L Wer Wo Was L1 1 L2 1 L1 2 L1 3 L1 4 L2 2 L2 3 L2 4 L1 5 L2 5 L1 6 L2 6 L1 7 L1 8 L1 9 S1 10 L2 7 L2 8 S1 11 L2 9 S2 10 S1 12 S2 11 S2 12 Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 37
4 Bemerkungen Warum schliessen sich einzelne Schreiber und die Gruppe aller Leser gegenseitig aus? Um zu schreiben, muss man das Semaphor W passiert haben Solange kein V(W) gemacht wurde, blockieren alle Schreiber Solange noch mindestens ein Leser liest, ist das Semaphor W auch gesperrt, alle Schreiber blockieren am P(W) Wofür braucht man das Semaphor Mutex? Ohne Mutex könnte zwischen Readcount++ und der Überprüfung ein Thread-Wechsel stattfinden Wenn zwei Leser "gleichzeitig" Readcount erhöhen, könnten Leser lesen, ohne ein P(W) gemacht zu haben Wie fair ist die Lösung? Solange mindestens ein Leser liest, kann kein Schreiber schreiben Leser können sich immer abwechseln und so alle Schreiber ausblocken (sie dürfen nur das Semaphor W nie "loslassen") Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 38
5 Zweites Leser-Schreiber-Problem Grundszenario wie erstes Leser-Schreiber-Problem Jetzt sollen aber die Schreiber Priorität haben! Was bedeutet Priorität? Zugriff eines Schreibers soll zum "frühestmöglichen" Zeitpunkt erlaubt werden Wenn noch Leser lesen, aber Schreiber schreiben möchten, darf kein neuer Leser beginnen zu lesen Ein Leser darf erst wieder lesen, wenn ein aktueller Schreiber aufgehört hat zu schreiben und kein Schreiber mehr schreiben will Bei einer offenen Wettbewerbssituation (Datenbereich ist frei, ein Schreiber möchte schreiben, mehrere Leser möchten lesen) darf maximal ein Leser dem Schreiber zuvorkommen Komplexes Problem, einfache Lösung mit Semaphoren Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 39
6 Beispiel int Readcount = 0; int Writecount = 0; Semaphor Mutex1 = 1, Mutex2 = 1, Mutex3 = 1, W = 1, R = 1; in blau: Code des ersten Leser-Schreiber-problems // Zugriff eines Leser-Threads: P(Mutex3); P(R); P(Mutex1); Readcount++; if (Readcount == 1) P(W); V(Mutex1); V(R); V(Mutex3); // lese Daten P(Mutex1); Readcount--; if (Readcount == 0) V(W); V(Mutex1) // Zugriff eines Schreiber-Threads P(Mutex2); Writecount++; if (Writecount == 1) P(R); V(Mutex2); P(W); // schreibe Daten V(W); P(Mutex2); Writecount--; if (Writecount == 0) V(R); V(Mutex2); Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 40
7 Bemerkungen Semaphor W hat dieselbe Bedeutung wie vorher Readcount hat dieselbe Bedeutung wie vorher Mutex1 schützt den exklusiven Zugriff auf Readcount Writecount zählt die Anzahl der bereiten Schreiber Mutex2 regelt exklusiven Zugriff auf Writecount Semaphor R realisiert die Priorität der Schreiber: R definiert einen kritischen Abschnitt, um den sich sowohl Leser als auch Schreiber bewerben R wird von Schreibern erst dann aufgegeben, wenn kein weiterer Schreiber sich beworben hat Mit dem Semaphor Mutex3 wird erreicht, dass sich alle Leser nacheinander um den Eintritt in R bewerben So kann maximal ein Leser einem Schreiber zuvorkommen Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 41
8 // Zugriff eines Leser-Threads: P(Mutex3); P(R); P(Mutex1); Readcount++; if (Readcount == 1) P(W); V(Mutex1); V(R); V(Mutex3); // lese Daten P(Mutex1); Readcount--; if (Readcount == 0) V(W); V(Mutex1) Ablaufbeispiel // Zugriff eines Schreiber-Threads P(Mutex2); Writecount++; if (writecount == 1) P(R); V(Mutex2); P(W); // schreibe Daten V(W); P(Mutex2); Writecount--; if (Writecount == 0) V(R); V(Mutex2); Readcount W.z W.L R.z R.L Mutex3.z Mutex3.L Kommentar Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 42
9 Erläuterung Leser1 beginnt zu lesen, anschliessend ist Readcount = 1, Semaphor W ist belegt Leser2 möchte lesen, Readcount = 2, geht direkt in den kritischen Abschnitt Leser3, Leser4 und Schreiber1 treten in direkte Wettbewerbssituation: alle drei starten parallel ihr Eintrittsprotokoll Leser3 und Leser4 streiten sich um Mutex3: Nur einer (z.b. Leser3) kommt durch, Leser4 blockiert an P(Mutex3) Leser3 und Schreiber konkurrieren um R: Nur einer (z.b. Schreiber) kommt durch, Leser3 blockiert an P(R) Schlimmstenfalls hätte Schreiber nur einen Leser vorlassen müssen Ergebnis: Leser4 blockiert an P(Mutex3), Leser3 blockiert an P(R), Schreiber blockiert an P(W) kein neuer Leser kommt in den kritischen Abschnitt Wenn Leser1 und Leser2 den kritischen Abschnitt verlassen, deblockiert Schreiber und geht in seinen kritischen Abschnitt Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 43
10 Bedingte kritische Abschnitte Eintritt in den kritischen Abschnitt hängt manchmal von einem Prädikat ab Prädikat kann über den im kritischen Abschnitt geschützten Daten definiert sein und muss deswegen auch geschützt werden Beispiel: DVD-Laufwerke, die auch defekt sein können Eintritt nur, falls es noch ein freies DVD-Laufwerk gibt, was nicht defekt ist Naive Implementierung: Semaphore Mutex = 1; P(Mutex); while (!Prädikat) { V(Mutex); NOP; P(Mutex); // Datenzugriff V(Mutex); Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 44
11 Bessere Lösung Naive Lösung implementiert wieder aktives Warten! In diesem Fall kann es bei ungünstiger Prozessorzuteilung zu einem Aushungern der Threads kommen Idee der besseren Lösung: Nur wenn die Daten modifiziert wurden, braucht man das Prädikat neu zu überprüfen Blockiere solange an zweitem Semaphor Condsem, bis die Daten modifiziert wurden Mit Zähler Waitcount wird gezählt, wieviele Threads die Bedingung prüfen wollen Bei Modifikation der Daten, Waitcount-Mal ein Ereignis auf Condsem generieren Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 45
12 Beispiel Semaphore Mutex = 1, Condsem = 0; int Waitcount = 0;... P(Mutex); while (!Prädikat) { Waitcount++; V(Mutex); P(Condsem); P(Mutex); // Datenzugriff while (Waitcount > 0) { Waitcount--; V(Condsem); V(Mutex); Semaphore Mutex = 1; P(Mutex); while (!Prädikat) { V(Mutex); NOP; P(Mutex); // Datenzugriff V(Mutex); Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 46
13 Zusammenfassung Semaphore Semaphore: Üblicherweise implementiert auf Ebene des Dispatchers Bei UL-Threads kann man Semaphore auch auf Anwendungsebene realisieren (mehr siehe Übung) Für Echtzeitverarbeitung können die Semaphor-Listen prioritätsgesteuert werden Semaphore sind eine sehr mächtige Abstraktion Man kann mit ihnen schnell und einfach Lösungen zu Synchronisationsproblemen schreiben Komplexe Anforderungen resultieren oft in komplexen, fehleranfälligen Lösungen Semaphore sind für die Betriebssystemprogrammierung gut, schlecht für die Programmierung auf Anwendungsebene Gesucht: Sprachkonzept für leichter verständliche Lösungen auf Ebene einer Programmiersprache Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 47
14 Übersicht Einführung: Kritische Abschnitte Hardwaregestützte Mechanismen Betriebssystemgestützter Mechanismus: Semaphore Sprachgestützter Mechanismus: Monitore Programmiersprachliche Realisierung Implementierung mit Semaphoren Realisierungsbeispiele Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 48
15 Monitorkonzept Schon in den 1970er Jahren wurde klar, dass für die Software-Entwicklung noch abstraktere Synchronisationsformen notwendig waren Das Monitorkonzept fand dabei die meiste Beachtung Zeitgleich erfunden von Brinch Hansen und Hoare Monitore kapseln kritische Daten und kritische Abschnitte in eine programmiersprachliche Einheit Monitore kann man sich als Module aus modulorientierten Sprachen oder Klassen in objektorientierten Sprachen denken Monitore fügen aber eine explizite Synchronisationssemantik hinzu Monitor = kritischer Abschnitt Es ist immer nur ein Prozess gleichzeitig "im Monitor" (d.h. führt eine Monitorprozedur aus) Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 49
16 Sprachliche Realisierung MONITOR Monitorname (Parameter) { Datendeklaration // gemeinsame Daten ENTRY Funktionsname1 (Parameter) { Prozedurkörper ENTRY Funktionsname2 (Parameter) { Prozedurkörper... ENTRY FunktionsnameN (Parameter) { Prozedurkörper INIT { Initialisierungscode Initialisierung eines Monitors: einmaliges Aufrufen von Monitorname(aktuelle Parameter) Aufruf einer Monitorprozedur: Monitorname.Funktionsname(aktuelle Parameter) Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 50
17 Synchronisation Vorteile von Monitoren Die Programmiersprache garantiert, dass auch bei mehreren parallelen Threads immer nur ein Thread gleichzeitig eine Monitorprozedur ausführt Monitorprozeduren sind also logisch atomar Kritische Daten werden explizit in der Programmstruktur sichtbar gemacht Die Zugriffsoperationen definieren die zulässigen Manipulationen der Monitordaten Ein Umgehen des Monitors ist nicht möglich Kapselung kritischer Daten Wie bei Modulen oder Klassen realisieren Monitore das Konzept des information hiding Zugriffsfunktionen verbergen die interne Struktur Erhöht die Wartbarkeit des Programmcodes Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 51
18 Beispiel: exklusive Ressourcen Jede exklusive benutzbare Ressource wird durch einen Monitor repräsentiert Prozeduren definieren die Zugriffsfunktionen Beispiel: Monitor Disc zur Synchronisation von Plattenzugriffen MONITOR Disc { ENTRY Read (Festplattenaddresse, Speicheradresse) { // Lesevorgang durchführen ENTRY Write (Speicheradresse, Festplattenadresse) { // Schreibvorgang durchführen INIT { // Gerät initialisieren Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 52
19 Condition-Variablen Zur einfachen Formulierung bedingter kritischer Abschnitte gehören zum Monitorkonzept sogenannte Condition- Variablen Spezielle Variablen, die Bedingungen über den Monitordaten repräsentieren Auf den Condition-Variablen kann man sich blockieren Aufruf: Conditionvariable.WAIT(); Bedeutung: Warte an dieser Stelle, bis die Bedingung der Conditionvariable gilt Man kann andere Threads aufwecken, die an einer Conditionvariablen warten Aufruf: Conditionvariable.SIGNAL(); Bedeutung: abhängig von der Signal-Semantik (es gibt drei verschiedene) Man kann testen, wieviele Threads warten Aufruf: Conditionsvariable.STATUS(); liefert int Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 53
20 WAIT und SIGNAL Zu einer Condition gehört immer eine einfache FIFO- Warteschlange für Threads Ähnlich wie bei Semaphoren: Kann für Echtzeitzwecke auch prioritätsbasiert sein Wirkung von WAIT() Der ausführende Thread blockiert sich in die Warteschlange der Conditionvariable Falls noch ein Thread den Zugang in den Monitor verlangt hat, deblockiere einen solchen Thread Ansonsten wird der Monitor freigegeben Wirkung von SIGNAL() (Variante 1) Deblockiere einen Thread, falls einer an der Warteschlange der Conditionvariable wartet Stelle sicher, dass nach Beendigung der SIGNAL-Operation höchstens ein Thread im Monitor rechnet Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 54
21 Beispiel Bedingter kritischer Abschnitt: MONITOR SingleResource { int busy; // >0 bedeutet frei, <1 bedeutet belegt Condition nonbusy; ENTRY Aquire { while (busy < 1) nonbusy.wait(); busy--; ENTRY Release { busy++;... nonbusy.signal(); INIT { busy = 1; Kapseln der kritischen Abschnitte: SingleResource.Aquire() // kritischer Abschnitt SingleResource.Release()... Vorlesung Betriebssysteme, Universität Mannheim, Herbstsemester 2010, Teil 6 55
Erzeuger-Verbraucher-Problem
Erzeuger-Verbraucher-Problem Hier: Puffer der Größe 1, Erzeuger, Verbraucher Zwei Semaphore werden eingesetzt, um zwischen Threads "Ereignisse zu melden" Man kann Semaphore auch verwenden, um Ereignisse
Betriebssysteme. Vorlesung im Herbstsemester 2010 Universität Mannheim. Kapitel 6: Speicherbasierte Prozessinteraktion
Betriebssysteme Vorlesung im Herbstsemester 2010 Universität Mannheim Kapitel 6: Speicherbasierte Prozessinteraktion Felix C. Freiling Lehrstuhl für Praktische Informatik 1 Universität Mannheim Vorlesung
Leser-Schreiber-Realisierung mit Semaphoren
Leser-Schreiber-Realisierung mit Semaphoren Reader: down(semwriter); down(semcounter); rcounter++; up(semwriter); read(); down(semcounter); rcounter--; Writer: Problem: down(semwriter); Busy Waiting siehe
Aufgabenblatt 7 Musterlösung
Prof. Dr. rer. nat. Roland Wismüller Aufgabenblatt 7 Musterlösung Vorlesung Betriebssysteme I Wintersemester 2017/18 Aufgabe 1: Steuerung eines Warenautomaten (Bearbeitung zu Hause) Anleitung wie man solche
Übung Betriebssysteme 11
Übung Betriebssysteme 11 Christian Motika Christian-Albrechts-Universität zu Kiel Institut für Informatik AG Echtzeitsysteme / Eingebettete Systeme Kiel, Germany 29-JAN-2013 CAU - WS 2012/13 Übung Betriebssysteme
Monitore. Klicken bearbeiten
Sascha Kretzschmann Institut für Informatik Monitore Formatvorlage und deren Umsetzung des Untertitelmasters durch Klicken bearbeiten Inhalt 1. Monitore und Concurrent Pascal 1.1 Warum Monitore? 1.2 Monitordefinition
Übung zu Grundlagen der Betriebssysteme. 10. Übung 18.12.2012
Übung zu Grundlagen der Betriebssysteme 10. Übung 18.12.2012 Aufgabe 1 a) Was versteht man unter einem kritischen Abschnitt oder kritischen Gebiet (critical area)? b) Welche Aufgabe hat ein Semaphor? c)
Info B VL 16: Monitore und Semaphoren
Info B VL 16: Monitore und Semaphoren Objektorientiere Programmierung in Java 2003 Ute Schmid (Vorlesung) Elmar Ludwig (Übung) FB Mathematik/Informatik, Universität Osnabrück Info B VL 16: Monitore und
Softwarelösungen: Versuch 4
Softwarelösungen: Versuch 4 Nichtstun in Schleife wird ersetzt durch zeitweilige Zurücknahme der Anforderung, um es anderen Prozessen zu erlauben, die Ressource zu belegen: /* Prozess 0 */ wiederhole flag[0]
#define N 5 // Anzahl der Philosophen. while (TRUE) { // Der Philosoph denkt
Sep 19 14:20:18 amd64 sshd[20494]: Accepted rsa for esser from ::ffff:87.234.201.207 port 61557 Sep 19 14:27:41 amd64 syslog-ng[7653]: STATS: dropped 0 Sep 20 01:00:01 amd64 /usr/sbin/cron[29278]: (root)
Pthreads. David Klaftenegger. Seminar: Multicore Programmierung Sommersemester
Seminar: Multicore Programmierung Sommersemester 2009 16.07.2009 Inhaltsverzeichnis 1 Speichermodell 2 3 Implementierungsvielfalt Prioritätsinversion 4 Threads Speichermodell Was sind Threads innerhalb
Klausur zur Vorlesung Grundlagen der Betriebssysteme
Prof. Dr. L. Wegner Dipl.-Math. K. Schweinsberg Klausur zur Vorlesung Grundlagen der Betriebssysteme 19.2.2004 Name:... Vorname:... Matrikelnr.:... Studiengang:... Hinweise: Bearbeitungszeit 2 Stunden.
Betriebssysteme Teil 11: Interprozess-Kommunikation
Betriebssysteme Teil 11: Interprozess-Kommunikation 19.12.15 1 Übersicht Grundbegriffe Shared Memory Pipelines Messages Ports Sockets 2 Grundbegriffe Interprocess-Kommunikation = Austausch von Daten über
Softwaresysteme I Übungen Jürgen Kleinöder Universität Erlangen-Nürnberg Informatik 4, 2007 U9.fm
U9 9. Übung U9 9. Übung U9-1 Überblick Besprechung Aufgabe 6 (printdir) Posix-Threads U9.1 U9-2 Motivation von Threads U9-2 Motivation von Threads UNIX-Prozesskonzept: eine Ausführungsumgebung (virtueller
Klausur am
Vorlesung Betriebssysteme I Wintersemester 2004/2005 Fachbereich 12, Elektrotechnik und Informatik Betriebssysteme / verteilte Systeme Prof. Roland Wismüller Klausur am 04.04.2005 Name: Vorname: Matrikelnummer:
Die Anweisungen zweier Prozesse werden parallel bearbeitet, wenn die Anweisungen unabhängig voneinander zur gleichen Zeit ausgeführt werden.
7 Parallelität und Nebenläufigkeit Mehrere Prozessen oder Threads Parallelität Die Anweisungen zweier Prozesse werden parallel bearbeitet, wenn die Anweisungen unabhängig voneinander zur gleichen Zeit
Betriebssysteme. G: Parallele Prozesse. (Teil B: Klassische Problemstellungen, Mutual Exclusion, kritische Regionen)
Betriebssysteme G: Parallele Prozesse (Teil B: Klassische Problemstellungen, Mutual Exclusion, kritische Regionen) 1 Allgemeine Synchronisationsprobleme Wir verstehen ein BS als eine Menge von parallel
Aufgaben Semaphore Übersicht (Dijkstra)
Übersicht (Dijkstra) Einsatz von Semaphoren: Wechselseitiger Ausschluss (INIT = 1): REQ. Kritischer Bereich. REL Zählende Semaphore (INIT = N): Bis zu N verschiedene Prozesse dürfen in den kritischen Bereich
Prozeß P1 Prozeß P2. Zur Synchronisation stehen den beiden Prozessen binäre Semaphore und die beiden Funktionen
Seite 8 A UFGABE 11 INTERP ROZEßKOMMUNIKATION Das folgende Petrinetz zeigt zwei verkoppelte Prozesse P1 und P2. Die Transitionen a und b beschreiben Aktionen von P1, die Transitionen c und d Aktionen von
POSIX-Threads. Aufgabe 9 SP - Ü U10.1
U10 10. Übung U10 10. Übung POSIX-Threads Aufgabe 9 U10.1 U10-1 Motivation von Threads U10-1 Motivation von Threads UNIX-Prozesskonzept: eine Ausführungsumgebung (virtueller Adressraum, Rechte, Priorität,...)
Aufgabenblatt 8 Musterlösung
Prof. Dr. rer. nat. Roland Wismüller Aufgabenblatt 8 Musterlösung Vorlesung Betriebssysteme I Wintersemester 2017/18 Aufgabe 1: Erzeuger-Verbraucher Synchronisation (Bearbeitung in der Übungsstunde) Erzeuger-Verbraucher-Problem:
2. Aufgabenblatt Threads
Fakultät Informatik Institut für Systemarchitektur, Professur für Betriebssysteme Betriebssysteme und Sicherheit, WS 2016/17 2. Aufgabenblatt Threads Geplante Bearbeitungszeit: drei Wochen TEIL A THREADS
Informatik B. Vorlesung 8 Synchronisierung von Threads. Dr. Ralf Kunze
Vorlesung 8 Synchronisierung von Threads 1 Rückblick Threads Erzeugen, Starten und Stoppen Fehler abfangen Gemeinsamer Zugriff auf Ressourcen Kritische Blöcke (Einleitung) 2 Kritische Blöcke Kritische
Einführung: Zustandsdiagramme Stand:
Einführung: Zustandsdiagramme Stand: 01.06.2006 Josef Hübl (Triple-S GmbH) 1. Grundlagen Zustandsdiagramme Zustände, Ereignisse, Bedingungen, Aktionen 2. Verkürzte Darstellungen Pseudozustände 3. Hierarchische
Inhaltsverzeichnis. Carsten Vogt. Nebenläufige Programmierung. Ein Arbeitsbuch mit UNIX/Linux und Java ISBN:
Inhaltsverzeichnis Carsten Vogt Nebenläufige Programmierung Ein Arbeitsbuch mit UNIX/Linux und Java ISBN: 978-3-446-42755-6 Weitere Informationen oder Bestellungen unter http://www.hanser.de/978-3-446-42755-6
Klausur Nichtsequentielle Programmierung
Klausur Nichtsequentielle Programmierung Prof. Dr. Marcel Kyas 22. Juli 2009 Nachname: Bachelor Magister Vorname: Master Lehramt Diplom Hinweise zur Klausur Bitte überprüfen Sie, dass Sie alle Seiten dieser
Inhaltsverzeichnis 1. Objektorientierung: Ein Einstieg 2. Objekte, Klassen, Kapselung
Inhaltsverzeichnis 1. Objektorientierung: Ein Einstieg... 1 1.1 Objektorientierung: Konzepte und Stärken...... 1 1.1.1 Gedankliche Konzepte der Objektorientierung....... 2 1.1.2 Objektorientierung als
Systemprogrammierung
Systemprogrammierung Prozesssynchronisation: Hochsprachenebene Wolfgang Schröder-Preikschat Lehrstuhl Informatik 4 12. Januar 2011 c wosch (Lehrstuhl Informatik 4) Systemprogrammierung WS2010/11 1 / 20
13 Abstrakte Datentypen
13 Abstrakte Datentypen Bisher: Konkrete Datentypen Menge von Elementen Operationen auf den Elementen (Konstruktoren, Selektoren, Typprädikate) Eigenschaften abgeleitet Jetzt: Abstrakte Datentypen (ADT)
Universität Stuttgart Institut für Automatisierungs- und Softwaretechnik Prof. Dr.-Ing. Dr. h. c. P. Göhner. Übung 5: Semaphoren
Universität Stuttgart Prof. Dr.-Ing. Dr. h. c. P. Göhner Aufgabe 5.1: Übung 5: Semaphoren Semaphor-Operationen In Bild 5.1.1 ist die Anordnung von Semaphor-Operationen am Anfang und am e der asks A,B,C
WS Parallele Prozesse. Prof. Hannelore Frank. Parallele Prozesse. PetriNetze. Synchronisation UNIX. Wettbewerb PC Krit.Abschnitt Spinlocks
WS 2007 Überblick 1 2 Petri-Netze als Entwurfshilfsmittel 3 nebenläufiger 4 -Systemfunktionen Literatur Eduard Glatz: Betriebssysteme. Grundlagen, Konzepte, Systemprogrammierung dpunkt.verlag, 2006, ISBN
Klausur zum Kurs Betriebssysteme (1802) am 19. September 2009
Fakultät für Mathematik und Informatik Lehrgebiet Kooperative Systeme Prof. Dr. Jörg M. Haake FernUniversität in Hagen 58084 Hagen Vorname Name Straße Hausnr. Informatikzentrum Universitätsstr. 1 58084
PThreads. Pthreads. Jeder Hersteller hatte eine eigene Implementierung von Threads oder light weight processes
PThreads Prozesse und Threads Ein Unix-Prozess hat IDs (process,user,group) Umgebungsvariablen Verzeichnis Programmcode Register, Stack, Heap Dateideskriptoren, Signale message queues, pipes, shared memory
Gliederung. Monitor (eine auf ein Modul bezogene) Klasse
Systemprogrammierung Prozesssynchronisation: Hochsprachenebene Wolfgang Schröder-Preikschat Lehrstuhl Informatik 4 04. November 2014 c wosch (Lehrstuhl Informatik 4) Systemprogrammierung SP2 # WS 2014/15
Thread-Synchronisation in in Java. Threads Wechselseitiger Ausschluss Bedingte Synchronisation Beispiel: Warteschlangen
Thread-Synchronisation in in Java Threads Wechselseitiger Ausschluss Bedingte Synchronisation Beispiel: Warteschlangen Die Klasse Thread Die Die Klasse Thread gehört zur zur Standardbibliothek von von
Gliederung. Algorithmen und Datenstrukturen II. Java: Objektorientierung. Java: Objektorientierung. Objektorientierung in JAVA. D.
Gliederung Algorithmen und Datenstrukturen II in JAVA D. Rösner Institut für Wissens- und Sprachverarbeitung Fakultät für Informatik Otto-von-Guericke Universität Magdeburg Sommer 2009, 4. Mai 2009, c
Betriebssysteme Theorie
Betriebssysteme Theorie SS 2011 Hans-Georg Eßer Dipl.-Math., Dipl.-Inform. Foliensatz D (05.05.2011) Synchronisation 05.05.2011 Betriebssysteme-Theorie, Hans-Georg Eßer Folie D-1 Einführung (1) Es gibt
Intensivübung zu Algorithmen und Datenstrukturen
Intensivübung zu Algorithmen und Datenstrukturen Silvia Schreier Informatik 2 Programmiersysteme Martensstraße 3 91058 Erlangen Übersicht Programmierung Fallunterscheidung Flussdiagramm Bedingungen Boolesche
Systeme I: Betriebssysteme Kapitel 5 Nebenläufigkeit und wechselseitiger Ausschluss. Maren Bennewitz
Systeme I: Betriebssysteme Kapitel 5 Nebenläufigkeit und wechselseitiger Ausschluss Maren Bennewitz Version 18.12.2013 1 Inhalt Vorlesung Aufbau einfacher Rechner Überblick: Aufgabe, Historische Entwicklung,
Objektorientierte Programmierung (OOP)
orientierte Programmierung (OOP) 1. Motivation Die objektorientierte Sichtweise der Welt Als Motivation für die OOP sieht man sich am besten die reale Welt an: Die reale Welt besteht aus "en", z. B.: Gegenstände,
Memory Models Frederik Zipp
Memory Models Frederik Zipp Seminar: Programmiersprachen für Parallele Programmierung (SS 2010) Fakultät für Informatik - IPD SNELTING LEHRSTUHL PROGRAMMIERPARADIGMEN 1
2.3 Prozessverwaltung
Realisierung eines Semaphors: Einem Semaphor liegt genau genommen die Datenstruktur Tupel zugrunde Speziell speichert ein Semaphor zwei Informationen: Der Wert des Semaphors (0 oder 1 bei einem binären
Informationsverarbeitung im Bauwesen
12 im Bauwesen Markus Uhlmann 1 Zusammenfassung der 11. Vorlesung Objektorientierte Programmierung (OOP) Wozu eigentlich? Was unterscheidet OOP von traditionellen Techniken? Verwendung von vordefinierten
Betriebssystembau (BSB)
Betriebssystembau (BSB) 6. Übung http://ess.cs.tu-.de/de/teaching/ws2013/bsb/ Olaf Spinczyk [email protected] http://ess.cs.tu-.de/~os AG Eingebettete System Informatik 12, TU Dortmund Agenda Vorstellung
Übungsblatt 2: Betriebssysteme, Prozesse
Ludwig-Maximilians-Universität München München, 13.05.2009 Institut für Informatik Priv.-Doz. Dr. Peer Kröger Thomas Bernecker Einführung in die Informatik: Systeme und Anwungen SS 2009 Übungsblatt 2:
Systeme 1. Kapitel 6. Nebenläufigkeit und wechselseitiger Ausschluss
Systeme 1 Kapitel 6 Nebenläufigkeit und wechselseitiger Ausschluss Threads Die Adressräume verschiedener Prozesse sind getrennt und geschützt gegen den Zugriff anderer Prozesse. Threads sind leichtgewichtige
Objektorientierte Programmierung II
Objektorientierte Programmierung II OOP I Erlaubt Entwicklers, im Problemraum zu denken und zu arbeiten. Das Problem wird in eine Menge von Objekten zerlegt. Objekte wirken aufeinander, um das Problem
1 Aufgaben 1.1 Objektorientiert: ("extended-hamster") Sammel-Hamster
1 Aufgaben 1.1 Objektorientiert: ("extended-hamster") Sammel-Hamster Aufgabe: Bearbeitungszeit: ca. 1/4 Std) Schreiben Sie ein "objektorientiertes" Programm ("CuB_05_1") für das Sammeln der Körner. Aufgabenbeschreibung:
Musterlösung Prüfung WS 01/02
Musterlösung Prüfung WS 01/02 Fach: I3 Software-Technik (SEE, GRS, BTS) Teilprüfung: Betriebssysteme Tag: 29.01.2002 10:45 14.45 Raum: 1006 Bearbeitungszeit: 4 Stunden Name:... Matr.Nr.:... Punkte:...
Übung zur Vorlesung Wissenschaftliches Rechnen Sommersemester 2012 Auffrischung zur Programmierung in C++, 2. Teil
MÜNSTER Übung zur Vorlesung Wissenschaftliches Rechnen Sommersemester 2012 Auffrischung zur Programmierung in C++ 2. Teil 18. April 2012 Organisatorisches MÜNSTER Übung zur Vorlesung Wissenschaftliches
Einführung in die Objektorientierte Programmierung Vorlesung 18: Lineare Datenstrukturen. Sebastian Küpper
Einführung in die Objektorientierte Programmierung Vorlesung 18: Lineare Datenstrukturen Sebastian Küpper Unzulänglichkeit von Feldern Wenn ein Unternehmen alle Rechnungen eines Jahres verwalten möchte,
Gegenseitiger Ausschluss 102
Gegenseitiger Ausschluss 102 MX = M (P 1... P n ) M = (lock unlock M) P i = (lock begin_critical_region i end_critical_region i unlock private_work i P i ) n Prozesse P 1... P n wollen konkurrierend auf
Überschreiben von Methoden
Vergleich der DoME Realisierungen: Methode ausgeben Version 1 (ohne Vererbung): Anzeigen aller Informationen CD: A Swingin Affair (64 Min)* Frank Sinatra Titelanzahl: 16 Mein Lieblingsalbum von Sinatra
Nebenläufigkeit mit Java
Nebenläufigkeit mit Java Einheit 01: Einführung in das Java-Threadkonzept Lorenz Schauer Lehrstuhl für Mobile und Verteilte Systeme Heutige Agenda Organisatorisches Ziele, Aufbau und Inhalte Zielgruppe,
Parallele Prozesse. Prozeß wartet
Parallele Prozesse B-66 Prozeß: Ausführung eines Programmes in seinem Adressraum (zugeordneter Speicher) Parallele Prozesse: gleichzeitig auf mehreren Prozessoren laufende Prozesse p1 p2 verzahnte Prozesse:
Ausnahmebehandlung in Java
Ausnahmebehandlung in Java class A { void foo() throws Help, SyntaxError {... class B extends A { void foo() throws Help { if (helpneeded()) throw new Help();... try {... catch (Help e) {... catch (Exception
Wegweiser. Das Erzeuger-/Verbraucher-Problem. Semaphore. Transaktionen. Botschaften
Wegweiser Das Erzeuger-/Verbraucher-Problem Semaphore Transaktionen Botschaften Betriebssysteme WS 2013, Threads 75 Beispiele Erzeuger-/Verbraucher-Probleme Betriebsmittelverwaltung Warten auf eine Eingabe
Vorlesung Objektorientierte Programmierung Klausur
Prof. Dr. Stefan Brass 16. Februar 2007 Dipl.-Inform. Annett Thüring Institut für Informatik MLU Halle-Wittenberg Vorlesung Objektorientierte Programmierung Klausur Name: Matrikelnummer: Studiengang: Aufgabe
Was machen wir heute? Betriebssysteme Tutorium 3. Organisatorisches. Prozesskontrollblock (PCB) Programmieraufgaben. Frage 3.1.a
Was machen wir heute? Betriebssysteme Tutorium 3 Philipp Kirchhofer [email protected] http://www.stud.uni-karlsruhe.de/~uxbtt/ Lehrstuhl Systemarchitektur Universität Karlsruhe (TH) 1
Threads. Foliensatz 8: Threads Folie 1. Hans-Georg Eßer, TH Nürnberg Systemprogrammierung, Sommersemester 2015
Sep 19 14:20:18 amd64 sshd[20494]: Accepted rsa for esser from ::ffff:87.234.201.207 port 61557 Sep 19 14:27:41 amd64 syslog-ng[7653]: STATS: dropped 0 Sep 20 01:00:01 amd64 /usr/sbin/cron[29278]: (root)
Nebenläufige Programmierung
Nebenläufige Programmierung Perspektiven der Informatik 27. Januar 2003 Gert Smolka Telefon-Szenario Eine Telefonzelle Mehrere Personen wollen telefonieren Immer nur eine Person kann telefonieren Ressource
e) Welche Aussage zu Speicherzuteilungsverfahren ist falsch?
Aufgabe 1: (1) Bei den Multiple-Choice-Fragen ist jeweils nur eine richtige Antwort eindeutig anzukreuzen. Auf die richtige Antwort gibt es die angegebene Punktzahl. Wollen Sie eine Multiple-Choice-Antwort
