Überblick. Middleware - Übung. Threads in Java. Was ist ein Thread? Multithreading in Java Threads Synchronisation Koordinierung
|
|
|
- Christa Vogt
- vor 9 Jahren
- Abrufe
Transkript
1 Überblick Middleware - Übung Tobias Distler, Michael Gernoth, Rüdiger Kapitza Friedrich-Alexander-Universität Erlangen-Nürnberg Lehrstuhl Informatik 4 (Verteilte Systeme und Betriebssysteme) www4.informatik.uni-erlangen.de Multithreading in Java Threads Synchronisation Koordinierung Wintersemester 2009/2010 MW-Übung (WS09/10) Multithreading in Java 1 31 Was ist ein Thread? Threads in Java Aktivitätsträger mit eigenem Ausführungskontext Instruktionszähler Register Stack Alle Threads laufen im gleichen Adressbereich Arbeit auf lokalen Variablen Kommunikation mit anderen Threads Vorteile Ausführen paralleler Algorithmen auf einem Multiprozessorrechner Durch das Warten auf langsame Geräte (z.b. Netzwerk, Benutzer) wird nicht das gesamte Programm blockiert Nachteile Komplexe Semantik Fehlersuche schwierig Attribute von Java-Threads Priorität 10 Stufen: von Thread.MIN PRIORITY (1) über Thread.NORM PRIORITY (5) bis Thread.MAX PRIORITY (10) Lassen sich auf Betriebssystemprioritäten mappen (stark systemabhängig) Daemon-Eigenschaft Daemon-Threads werden für Hintergrundaktivitäten genutzt Sobald alle Nicht-Daemon-Threads beendet sind, ist auch das Programm beendet Beachte: Thread-Attribute gehen auf neu erzeugte Threads über : Daemon-Thread A mit Priorität 7 erzeugt Thread B Thread B ist Daemon und hat ebenfalls Priorität 7 MW-Übung (WS09/10) Multithreading in Java Threads 2 31 MW-Übung (WS09/10) Multithreading in Java Threads 3 31
2 Erzeugung von Threads in Java java.lang.thread Erzeugung von Threads in Java java.lang.runnable Variante 1: Unterklasse von java.lang.thread Vorgehensweise 1. Unterklasse von java.lang.thread erstellen 2. run()-methode überschreiben 3. Instanz der neuen Klasse erzeugen 4. An dieser Instanz die start()-methode aufrufen class ThreadTest extends Thread { public void run () { System. out. println (" Test "); ThreadTest test = new ThreadTest (); test. start (); Variante 2: Implementieren von java.lang.runnable Vorgehensweise 1. Die run()-methode der Runnable-Schnittstelle implementieren 2. Objekt der neuen Klasse erzeugen, das Runnable implementiert 3. Instanz von Thread erzeugen, dem Konstruktor dabei das Runnable-Objekt mitgeben 4. Am neuen Thread-Objekt die start()-methode aufrufen class RunnableTest implements Runnable { public void run () { System. out. println (" Test "); RunnableTest test = new RunnableTest (); Thread thread = new Thread ( test ); thread. start (); MW-Übung (WS09/10) Multithreading in Java Threads 4 31 MW-Übung (WS09/10) Multithreading in Java Threads 5 31 Pausieren von Threads sleep(), yield() Beenden von Threads return, interrupt() Ausführung für einen bestimmten Zeitraum aussetzen Mittels sleep()-methoden static void sleep ( long millis ); static void sleep ( long millis, int nanos ); Legt den aktuellen Thread für millis Millisekunden (und nanos Nanosekunden),,schlafen Achtung: Es ist nicht garantiert, dass der Thread exakt nach der angegebenen Zeit wieder aufwacht Ausführung auf unbestimmte Zeit aussetzen Mittels yield()-methode static void yield(); Gibt die Ausführung zugunsten anderer Threads auf Keine Informationen über die Dauer der Pause Synchron Ausführung erreicht ein return aus der run()-methode das Ende der run()-methode Asynchron Mittels interrupt()-methode public void interrupt(); Wird (normalerweise) von außen aufgerufen Führt zu einer InterruptedException, falls sich der Thread gerade in einer unterbrechbaren blockierenden Operation befindet einer ClosedByInterruptException, falls sich der Thread gerade in einer unterbrechbaren IO-Operation befindet dem Setzen einer Interrupt-Status-Variable, die mit isinterrupted() abgefragt werden kann, sonst. MW-Übung (WS09/10) Multithreading in Java Threads 6 31 MW-Übung (WS09/10) Multithreading in Java Threads 7 31
3 Beenden von Threads join() Veraltete Methoden Auf die Beendigung von anderen Threads warten Mittels join()-methode public void join() throws InterruptedException; MyWorker worker = new MyWorker (); // implementiert Runnable Thread workerthread = new Thread ( worker ); workerthread. start (); try { workerthread. join (); worker. result (); catch ( InterruptedException ie) { // Unterbrechungsbehandlung fuer join () Als,,deprecated markierte Thread-Methoden stop(): Thread-Ausführung stoppen destroy(): Thread löschen (ohne Aufräumen) suspend(): Thread-Ausführung anhalten resume(): Thread-Ausführung fortsetzen... Gründe stop() gibt alle Locks frei, die der Thread gerade hält kann zu Inkonsistenzen führen destroy() und suspend() geben keine Locks frei Weitere Informationen Why are Thread.stop, Thread.suspend and Thread.resume Deprecated? MW-Übung (WS09/10) Multithreading in Java Threads 8 31 MW-Übung (WS09/10) Multithreading in Java Threads 9 31 Thread-Zustände in Java NEW start() yield() Warten auf IO Warten auf ein Lock sleep() RUNNABLE BLOCKED/ WAITING/ TIMED_WAITING IO bereit Lock verfügbar Zeit abgelaufen Multithreading in Java Threads Synchronisation Koordinierung run() beendet TERMINATED MW-Übung (WS09/10) Multithreading in Java Threads MW-Übung (WS09/10) Multithreading in Java Synchronisation 11 31
4 Korrektheit nebenläufiger Programme Hauptaugenmerk liegt meist auf zwei Prinzipien Safety,,Es passiert niemals etwas Schlechtes e: Korrekte Berechnungen Korrekte (Zwischen-)Zustände Korrekte Ergebnisse... Liveness,,Es passiert überhaupt irgendetwas e: Keine Deadlocks Stetiger Programm-Fortschritt... Maßnahmen Synchronisation Koordinierung Synchronisationsbedarf: public class Adder implements Runnable { public int a = 0; public void run () { for ( int i = 0; i < ; i ++) { a = a + 1; public static void main ( String [] args ) throws Exception { Adder value = new Adder (); Thread t1 = new Thread ( value ); Thread t2 = new Thread ( value ); t1. start (); t2. start (); t1. join (); t2. join (); System. out. println (" Expected a = , " + " but a = " + value.a); MW-Übung (WS09/10) Multithreading in Java Synchronisation MW-Übung (WS09/10) Multithreading in Java Synchronisation Probleme mit Multithreading: Synchronisation in Java Ergebnis einiger Durchläufe: , , Was passiert, wenn a = a + 1 ausgeführt wird? LOAD a into Register ADD 1 to Register STORE Register into a Mögliche Verzahnung, wenn zwei Threads beteiligt sind 0. a = 0; 1. T1-load: a = 0, Reg1 = 0 2. T2-load: a = 0, Reg2 = 0 3. T1-add: a = 0, Reg1 = 1 4. T1-store: a = 1, Reg1 = 1 5. T2-add: a = 1, Reg2 = 1 6. T2-store: a = 1, Reg2 = 1 Die drei Operationen müssen atomar ausgeführt werden! Grundprinzip Vor Betreten eines kritischen Abschnitts muss ein Thread ein Sperrobjekt anfordern Beim Verlassen des kritischen Abschnitts wird das Sperrobjekt wieder freigegeben Ein Sperrobjekt wird zu jedem Zeitpunkt von nur maximal einem Thread gehalten Beachte In Java kann jedes Objekt als Sperrobjekt dienen Ein Thread kann das selbe Sperrobjekt mehrfach halten (rekursive Sperre) MW-Übung (WS09/10) Multithreading in Java Synchronisation MW-Übung (WS09/10) Multithreading in Java Synchronisation 15 31
5 Das Schlüsselwort synchronized Übersicht Das Schlüsselwort synchronized Nachteile Schutz von kritischen Abschnitten per synchronized-block public void foo () { // unkritische Operationen synchronized ( < Sperrobjekt >) { // zu schuetzender Code ( krit. Abschnitt ) // unkritische Operationen Ausweitung eines synchronized-blocks auf die komplette Methode synchronized public void bar () { // zu schuetzender Code ( kritischer Abschnitt ) Verbesserung für synchronized ( this ) { a = a + 1; Anforderung (lock()) und Freigabe (unlock()) des Sperrobjekts sind nur im Java-Byte-Code sichtbar nicht trennbar ( Vorteil: kein lock() ohne unlock()) Keine Timeouts beim Warten auf ein Sperrobjekt möglich Keine alternativen Semantiken (z.b. zur Implementierung von Fairness) definierbar Lösung: Alternative Synchronisationsvarianten (siehe später) MW-Übung (WS09/10) Multithreading in Java Synchronisation MW-Übung (WS09/10) Multithreading in Java Synchronisation Wann muss synchronisiert werden? Atomare Operationen java.util.concurrent.atomic Atomare Aufrufe erforderlich 1. Der Aufruf einer (komplexen) Methode muss atomar erfolgen Eine Methode enthält mehrere Operationen, die auf einem konsistenten Zustand arbeiten müssen e: -,,a = a Listen-Operationen (add(), remove(),...) 2. Zusammenhängende Methodenaufrufe müssen atomar erfolgen Methodenfolge muss auf einem konsistenten Zustand arbeiten : List list = new LinkedList (); int lastobjectindex = list. size () - 1; Object lastobject = list. get ( lastobjectindex ); Beachte: Code, der zu jedem Zeitpunkt nur von einem einzigen Thread ausgeführt wird (single-threaded context), muss nicht synchronisiert werden! Allgemein Ersatz-Klassen (keine Unterklassen!) für problematische Datentypen Atomare Varianten häufig verwendeter Operationen Compare-and-Swap (CAS) für Java Verfügbare Klassen Versionen für primitive Datentypen: AtomicBoolean, AtomicInteger, AtomicLong Erweiterte Klassen für Arrays: AtomicIntegerArray, AtomicLongArray Referenzen: AtomicReference, AtomicReferenceArray... AtomicInteger ai = new AtomicInteger (47); int newvalue0 = ai. incrementandget (); // entspricht : ++ i; int newvalue1 = ai. getandincrement (); // entspricht : i ++; int oldvalue = ai. getandset (4); boolean success = ai. compareandset ( oldvalue, 7); MW-Übung (WS09/10) Multithreading in Java Synchronisation MW-Übung (WS09/10) Multithreading in Java Synchronisation 19 31
6 Synchronisierte Datenstrukturen java.util.collections Optimistische Nebenläufigkeitskontrolle Die Klasse java.util.collections Idee Statische Wrapper-Methoden für java.util.collection-objekte Synchronisation kompletter Datenstrukturen Methoden static <T > List <T > synchronizedlist ( List <T > list ); static <K,V> Map <K,V> synchronizedmap (Map <K,V> m); static <T> Set <T> synchronizedset (Set <T> s); List < String > list = new LinkedList < String >(); List < String > synclist = Collections. synchronizedlist ( list ); Beachte Synchronisiert alle Zugriffe auf eine Datenstruktur Löst Fall 1, jedoch nicht Fall 2 (siehe frühere Folie) MW-Übung (WS09/10) Multithreading in Java Synchronisation Idee Operation (optimistisch/spekulativ) ausführen Bei Bedarf Objektzustand korrigieren und Operation erneut ausführen Varianten Rollback/Recovery Zu jeder Operation muss eine Umkehroperation existieren Operationen müssen seiteneffektfrei sein Versioning Operationen arbeiten auf Shadow-Kopien des Objektzustands Atomares commit überprüft, ob sich der Ausgangszustand geändert hat ( Konflikt) und setzt Shadow-Zustand als neuen Objektzustand Vorteile Keine Deadlocks Reduzierung von Synchronisationskosten Nachteile Erhöhte Design-Komplexität Ungeeignet für hohe Last: je mehr parallele Zugriffe auf ein Objekt stattfinden, desto höher z.b. die Anzahl der Rollbacks MW-Übung (WS09/10) Multithreading in Java Synchronisation Optimistische Nebenläufigkeitskontrolle klasse: Zähler class Counter { private CounterState state ; // Objektzustand Operation auf Shadow-Kopie ausführen void increment () { CounterState assumed, next ; do { assumed = state ; next = new CounterState ( assumed ); next. inc (); // Shadow - Zustand modifizieren while (! commit ( assumed, next )); Änderung zurückschreiben synchronized boolean commit ( CounterState assumed, CounterState next ) { if( state!= assumed ) return false ; state = next ; return true ; Multithreading in Java Threads Synchronisation Koordinierung MW-Übung (WS09/10) Multithreading in Java Synchronisation MW-Übung (WS09/10) Multithreading in Java Koordinierung 23 31
7 Koordinierung Koordinierungsbedarf: Synchronisation alleine nicht ausreichend Jeder Thread,,lebt in seiner eigenen Welt Threads haben keine Möglichkeit sich abzustimmen Koordinierung unterstützt Verwaltung von gemeinsam genutzten Betriebsmitteln Rollenverteilung (z.b. Producer/Consumer) Gemeinsame Behandlung von Problemsituationen... Das,,Philosophen-Problem Erkenntnisse Das Leben eines Philosophen beschränkt sich auf 2 Tätigkeiten: Denken und Essen (abwechselnd) Zum Essen benötigt man Messer und Gabel Experiment 4 Philosophen werden an einem runden Tisch platziert Zwischen 2 Philosophen liegt jeweils ein Messer oder eine Gabel Messer und Gabel können nicht gleichzeitig genommen werden Da nicht ausreichend Besteck für alle vorhanden ist, legt jeder Philosoph sein Besteck nach dem Essen wieder zurück Problem, falls alle Philosophen zuerst das rechte und danach erst das linke Besteckteil nehmen wollen: Deadlock Koordinierung notwendig MW-Übung (WS09/10) Multithreading in Java Koordinierung MW-Übung (WS09/10) Multithreading in Java Koordinierung Koordinierung in Java Übersicht Koordinierung in Java Grundprinzip Ein Thread wartet darauf, dass eine Bedingung wahr wird oder ein Ereignis eintritt Der Thread wird mittels einer Synchronisationsvariable benachrichtigt Beachte Jedes Java-Objekt kann als Synchronisationsvariable dienen Um andere Threads über eine Synchronisationsvariable zu benachrichtigen, muss sich ein Thread innerhalb eines synchronized-blocks dieser Variable befinden Methoden wait(): auf eine Benachrichtigung warten notify(): Benachrichtigung an einen wartenden Thread senden notifyall(): Benachrichtigung an alle wartenden Thread senden Variablen Object syncobject = new Object (); // Synchronisations - Variable boolean condition = false ; // Bedingung Auf Erfüllung der Bedingung wartender Thread synchronized ( syncobject ) { while (! condition ) { syncobject. wait (); Bedingung erfüllender Thread synchronized ( syncobject ) { condition = true ; syncobject. notify (); MW-Übung (WS09/10) Multithreading in Java Koordinierung MW-Übung (WS09/10) Multithreading in Java Koordinierung 27 31
8 Explizite Locks java.util.concurrent.locks.lock ReentrantLock vs. synchronized Allgemeine Schnittstelle java.util.concurrent.locks.lock Lock anfordern void lock (); void lockinterruptibly () throws InterruptedException ; boolean trylock (); boolean trylock ( long time, TimeUnit unit ) throws InterruptedException ; Lock freigeben void unlock(); Condition-Variable für dieses Lock erzeugen Condition newcondition(); Implementierung: java.util.concurrent.locks.reentrantlock Lock lock = new ReentrantLock (); lock. lock (); lock. unlock (); Vor- und Nachteile im Vergleich ReentrantLock Mehr Features (Timeouts, Unterbrechbarkeit,...) Performanter Nicht an Code-Blöcke gebunden Schwieriger zu Debuggen synchronized JVM kann beim Debuggen helfen Einfacher zu benutzen Keine vergessenen unlock()s MW-Übung (WS09/10) Multithreading in Java Koordinierung MW-Übung (WS09/10) Multithreading in Java Koordinierung Bedingungsvariablen java.util.concurrent.locks.condition Semaphoren java.util.concurrent.semaphore Die Schnittstelle java.util.concurrent.locks.condition Auf Signal (= Erfüllung der Bedingung) warten void await () throws InterruptedException ; // vgl. wait () void awaituninterruptibly (); boolean await ( long time, TimeUnit unit ) throws InterruptedException ; boolean awaituntil ( Date deadline ) throws InterruptedException ; Signalisieren void signal (); // analog zu notify () void signalall (); // analog zu notifyall () Beachte Ein Thread der await*() oder signal*() aufruft muss das zugehörige Lock halten (vgl. wait() und notify*() innerhalb synchronized-block) Die Klasse java.util.concurrent.semaphore Konstruktoren Semaphore ( int permits ); Semaphore ( int permits, boolean fair ); Semaphore belegen (= herunter zählen) acquire ([ int permits ]) throws InterruptedException ; acquireuninterruptibly ([ int permits ]); tryacquire ([ int permits, ] [ long timeout ]); Semaphore freigeben (= herauf zählen) release([int permits]); Semaphore s = new Semaphore (1); s. acquireuninterruptibly (); s. release (); MW-Übung (WS09/10) Multithreading in Java Koordinierung MW-Übung (WS09/10) Multithreading in Java Koordinierung 31 31
Überblick. Verteilte Systeme - Übung. Was ist ein Thread? Threads in Java. Multithreading in Java Threads Synchronisation Koordinierung
Überblick Verteilte Systeme - Übung Friedrich-Alexander-Universität Erlangen-Nürnberg Lehrstuhl Informatik 4 (Verteilte Systeme und Betriebssysteme) www4.informatik.uni-erlangen.de Sommersemester 2009
Überblick. Generische Datenstrukturen. Traversieren von Datenstrukturen. Package: java.util
Überblick Collections Übersicht Package: java.util Java Collections & Maps Threads Gemeinsame Schnittstelle: Collection Datenstrukturen Menge Schnittstelle: Set Implementierungen: HashSet, TreeSet,...
D.1 Threads. 1 Was ist ein Thread? 2 Vorteile / Nachteile. Aktivitätsträger mit: Threads - Überblick. Synchronisation. Probleme
D Überblick über die 3. Übung D Überblick über die 3. Übung 1 Was ist ein Thread? Threads - Überblick Synchronisation Probleme Aktivitätsträger mit: eigenem Instruktionszähler eigenen Registern eigenem
C.1 Threads. 1 Was ist ein Thread? 2 Vorteile / Nachteile. Aktivitätsträger mit: Threads - Überblick. Synchronisation. Probleme
C Überblick über die 2. Übung C Überblick über die 2. Übung 1 Was ist ein Thread? Threads - Überblick Synchronisation Probleme Aktivitätsträger mit: eigenem Instruktionszähler eigenen Registern eigenem
C Threads. C.2 Vorteile / Nachteile. C.3 Thread Erzeugung: Möglichkeit 1. C.1 Was ist ein Thread? Vorteile: Referenz: Nachteile:
C.2 Vorteile / Nachteile C Threads Referenz: D. Lea. Concurrent Programming in Java - Design Principles and Patterns. The Java Series. Addison-Wesley 1999. Scott Oaks; Henry Wong - Java Threads, 3rd Edition
Ausgewählte Implementierungsprobleme
Ausgewählte Implementierungsprobleme Rebecca Tiarks 18. Dezember 2008 1 / 30 Inhaltsverzeichnis 1 2 3 Persistenzproblem & CSV Binärformat 2 / 30 Themenübersicht 1 18. Dez: + 2 8. Jan. Swing 3 15. Jan TCP,
Nebenläufigkeit mit Java
Nebenläufigkeit mit Java Einheit 03: Synchronisation Lorenz Schauer Lehrstuhl für Mobile und Verteilte Systeme Heutige Agenda Synchronisation von Threads Locks Java Monitor-Konzept Lock Freigabe Zusammenspiel
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
Praktikum aus Softwareentwicklung 2, Stunde 5
Praktikum aus Softwareentwicklung 2, Stunde 5 Lehrziele/Inhalt 1. Threads Threads Threads sind parallele, oder auf Rechnern mit nur einer CPU quasi-parallele, Programmabläufe in Java. Sie können beispielsweise
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
Nebenläufigkeit mit Java
Nebenläufigkeit mit Java Einheit 02: Eigenschaften & kritische Abläufe Lorenz Schauer Lehrstuhl für Mobile und Verteilte Systeme Heutige Agenda Eigenschaften von Threads Name, Priorität, Zustand Zustandsübergänge
Parallele Prozesse Prozeß Parallele Prozesse verzahnte Prozesse Nebenläufige Prozesse: Threads Vorlesung Software-Entwicklung / Folie 131 Ziele:
Parallele Prozesse SWE-131 Prozeß: Ausführung eines sequentiellen Programmstückes in dem zugeordneten Speicher (Adressraum). Veränderlicher Zustand: Speicherinhalt und Programmposition. Parallele Prozesse:
Lebenszyklus von Threads
Threads Umgangssprachlich Faden, Diskussionsfaden, Gewinde, Faser, Garn, roter Faden Threads ermöglichen Nebenläufigkeit (parallele Ausführung von Anwendungsteilen). Typisch für Threads ist,dass sie zu
parallele Prozesse auf sequenziellen Prozessoren Ein Process ist ein typisches Programm, mit eigenem Addressraum im Speicher.
Threads parallele Prozesse auf sequenziellen Prozessoren Prozesse und Threads Es gibt zwei unterschiedliche Programme: Ein Process ist ein typisches Programm, mit eigenem Addressraum im Speicher. Ein Thread
Nebenläufige Programmierung in Java: Threads
Nebenläufige Programmierung in Java: Threads Wahlpflicht: Fortgeschrittene Programmierung in Java Jan Henke HAW Hamburg 10. Juni 2011 J. Henke (HAW) Threads 10. Juni 2011 1 / 18 Gliederung 1 Grundlagen
Beispiel für überladene Methode
Beispiel für überladene Methode class Gras extends Futter {... abstract class Tier { public abstract void friss (Futter x); class Rind extends Tier { public void friss (Gras x) {... public void friss (Futter
Einführung in die Programmierung Blockkurs Java
Michael Bader 8. 12. April 2002 Freitag Inhaltsübersicht Exceptions und Errors Ausnahmebehandlung: try/catch/finally Threads Zugriffskontrolle bei gemeinsamen Variablen: synchronized, wait(), notify()
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
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,
Java Concurrency Utilities
Java Concurrency Utilities Java unterstützt seit Java 1.0 Multithreading Java unterstützt das Monitorkonzept mittels der Schlüsselworte synchronized und volatile sowie den java.lang.object Methoden wait(),
OOP: Nebenläufigkeiten Threads. Dipl.-Inform. Arnold Willemer
OOP: Nebenläufigkeiten Threads Dipl.-Inform. Arnold Willemer [email protected] Schlafen für Profis Die C-64-Lösung kocht und blockiert den Prozessor while (!fertig) // nichts tun: busy waiting
Vorkurs Informatik WiSe 15/16
Java 7 Dr. Werner Struckmann / Stephan Mielke, Jakob Garbe, 21.10.2015 Technische Universität Braunschweig, IPS Überblick OO in Java Vererbung Abstrakte Klassen und Interfaces 21.10.2015 Dr. Werner Struckmann
Institut für Programmierung und Reaktive Systeme. Java 7. Markus Reschke
Institut für Programmierung und Reaktive Systeme Java 7 Markus Reschke 14.10.2014 Vererbung in Java Vererbung ermöglicht es, Klassen zu spezialisieren Wiederverwendung vorhandener Klassen Kindsklasse erhält
Prozesszustände (1a)
Prozesszustände (1a) NOT EXISTING DELETED CREATED Meta-Zustand (Theoretische Bedeutung) Prozesszustände Multiuser Umfeld (1c) Hintergrund-Prozess - der Prozess startet im Hintergrund - my-commandbin &
Software Entwicklung 1
Software Entwicklung 1 Annette Bieniusa Peter Zeller AG Softech FB Informatik TU Kaiserslautern Speichermanagement Wie viel Speicher braucht ein Programm? Wofür wird Speicher benötigt? Wie ist der Speicher
5. Threads, Serverprozesse und Benachrichtigungen
5. Threads, Serverprozesse und Benachrichtigungen Threads allgemein Threads in Android: Handler und Messages Services: Local, Remote, Binding Benachrichtigungen Entwicklung mobiler Anwendungen Europäische
Dr. Monika Meiler. Inhalt
Inhalt 15 Parallele Programmierung... 15-2 15.1 Die Klasse java.lang.thread... 15-2 15.2 Beispiel 0-1-Printer als Thread... 15-3 15.3 Das Interface java.lang.runnable... 15-4 15.4 Beispiel 0-1-Printer
Institut für Programmierung und Reaktive Systeme. Java 6. Markus Reschke
Institut für Programmierung und Reaktive Systeme Java 6 Markus Reschke 13.10.2014 OOP Objekte = Verhalten (durch Methoden) + Daten (durch Attribute) Klassen = Baupläne für Objekte Kapselung von Programmteilen
Repetitorium Informatik (Java)
Repetitorium Informatik (Java) Tag 6 Lehrstuhl für Informatik 2 (Programmiersysteme) Übersicht 1 Klassen und Objekte Objektorientierung Begrifflichkeiten Deklaration von Klassen Instanzmethoden/-variablen
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:
Ü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)
Institut für Informatik. Endterm Klausur zu Informatik I 20. Februar 2010
Technische Universität München Institut für Informatik Lehrstuhl für Computer Graphik & Visualisierung Prof. R. Westermann Endterm Klausur zu Informatik I 20. Februar 2010 ˆ Die Arbeitszeit beträgt 120
Versuchsziele Konzepte der parallelen Programmierung am Beispiel von Threads anwenden können. Einbau von Kontrollmechanismen mittels Semaphore.
Hochschule Harz Versuch: fcopy Mit Java FB Automatisierung und Informatik Betriebssysteme Thema: Kopieren einer Datei unter der Kontrolle von Semaphoren Versuchsziele Konzepte der parallelen Programmierung
Programmierung mit Threads in Java
Programmierung mit Threads in Java Harald Kosch and Matthias Ohlenroth Institut für Informationstechnologie Universität Klagenfurt H. Kosch Threads in Java 1 Inhalt Grundlagen: Threads und Datenlokalität
Einführung Verteilte Systeme - Java Threads I -
Einführung Verteilte Systeme - Java Threads I - Prof. Dr. Michael Cebulla 20. November 2014 Fachhochschule Schmalkalden Wintersemester 2014/15 1 / 38 M. Cebulla Verteilte Systeme Gliederung Wiederholung:
Universität Karlsruhe (TH)
Universität Karlsruhe (TH) Lehrstuhl für Programmierparadigmen Fortgeschr. Objektorientierung SS 2009 http://pp.info.uni-karlsruhe.de/ Dozent: Prof. Dr.-Ing. G. Snelting [email protected]
Thread-Konzept in objektorientierten Programmiersprachen. Threads. Threads in Java
Thread-Konzept in objektorientierten Programmiersprachen 1 Threads ein Thread ist ein eigenständiges Programmfragment, das parallel zu anderen Teilen eines Programmes ablaufen kann alle Threads eines Programmes
Parallele und funktionale Programmierung Wintersemester 2015/ Übung Abgabe bis , 10:00 Uhr
3. Übung Abgabe bis 10.11.2015, 10:00 Uhr Aufgabe 3.1: Java-Synchronisation a) An welchen Stellen im Code kann das Schlüsselwort synchronized verwendet werden? b) Wie nennt sich die Synchronisations-Art,
Algorithmen und Datenstrukturen
Algorithmen und Datenstrukturen Tafelübung 03 Vererbung, Polymorphie, Sichtbarkeit, Interfaces Clemens Lang T2 11. Mai 2010 14:00 16:00, 00.152 Tafelübung zu AuD 1/26 Klassen und Objekte Klassen und Objekte
Nebenläufigkeit in Java. Prof. Dr. Margarita Esponda
Nebenläufigkeit in Java Prof. Dr. Margarita Esponda Gliederung der Vorlesung - Konzepte der Nebenläufigkeit -Threads in Java - Synchronisationsprobleme - Klassische Lösungen -Semaphoren - Monitore - Lebenszyklus
Multithreading ab Java 5: Die neuen Concurrency APIs
Multithreading ab Java 5: Die neuen Concurrency APIs Java Concurrency Spezifiziert in JSR166 Ab Java 5 fester Bestandteil von Java Durch zusätzliche Library auch vor Java 5 vorhanden backport-util-concurrent
Zur Erinnerung: Threads. Threadverwaltung. Threads: Prioritäten. Beispiel Flugbuchungsprogramm. Nichtdeterminismus
Zur Erinnerung: Threads Programmierung (fortgeschrittene Konzepte) Threads, Monitore, Semaphore und speisende en Wolf-Ulrich Raffel ([email protected]) Möglichkeiten, Threads zu definieren Bildung einer
Motivation. Informatik B - Objektorientierte Programmierung in Java. Vorlesung 20: Threads. Inhalt. Ein Beispiel zur Motivation
Universität Osnabrück 1 Motivation 3 - Objektorientierte Programmierung in Java Führt ein Applet eine lange Berechnung aus, so erfolgt keine Reaktion auf die Betätigung des Stop-Buttons am Browser bzw.
Programmieren II. Verklemmungen. Vorlesung 10. Handout S. 1. Dr. Klaus Höppner. Hochschule Darmstadt Sommersemester Deadlocks.
Programmieren II Dr. Klaus Höppner Hochschule Darmstadt Sommersemester 2010 1 / 33 Deadlocks Wait/Notify Reflections JavaBeans 2 / 33 Verklemmungen Solange es nur einen Lock bzw. nur ein Objekt gibt, über
Lösungsvorschläge zur Nachklausur zum Kurs 1618 Sommersemester 2001 am
Aufgabe 1 Lösungsvorschläge zur Nachklausur zum Kurs 1618 Sommersemester 2001 am 16.3.2002 Folgende Implementierung löst die gestellte Aufgabe : public interface Figur { public void anzeigen (); public
Tag 8 Repetitorium Informatik (Java)
Tag 8 Repetitorium Informatik (Java) Dozent: Michael Baer Lehrstuhl für Informatik 2 (Programmiersysteme) Friedrich-Alexander-Universität Erlangen-Nürnberg Wintersemester 2017/2018 Informatik-Repetitorium
Synchronisation in Java. Invisible Web
Synchronisation in Java Studienprojekt Invisible Web Tang Zhihong Synchronisation in Java Synchronisationsproblem Monitore Wait und notify PipedInputStream und PipedOutputStream Synchronisation von Collections
Programmieren in Java -Eingangstest-
Programmieren in Java -Eingangstest- Nummer: 1. Studiengang: Informatik B.Sc. Informatik M.Sc. ESE B.Sc. ESE M.Sc. Sonstiges: Fachsemester: Bitte Fragen, die Sie nicht beantworten können unbedingt mit
IT I: Heute. abstrakte Methoden und Klassen. Interfaces. Interfaces List, Set und Collection IT I - VO 7 1
IT I: Heute abstrakte Methoden und Klassen Interfaces Interfaces List, Set und Collection 22.11.2018 IT I - VO 7 1 Wissensüberprüfung Überschreiben von Methoden: Aufruf der Methode der Oberklasse ist oft
Informatik II. Semesterklausur
Universität Augsburg, Institut für Informatik Sommersemester 2003 Prof. Dr. Bernhard Bauer 5. Juli 2003 Stefan Fischer, Dr. Martin Müller Informatik II Semesterklausur Prüfungsmodul Informatik II (SS 2003)
Aufgabe 9 Threads [12]
Aufgabe 9 Threads [12] a) Teilaufgaben: Antworten u. Grafiken größtenteils den Vorlesungsfolien von A. Brüggemann-Klein entnommen. a. Erläutern Sie die Zustände ready, running, sleeping, dead, in denen
Softwaretechnik 1 Übung 5
Universität Karlsruhe (TH) Forschungsuniversität gegründet 1825 Softwaretechnik 1 Übung 5 2.7.29 Aufgabe 1a) Zeichnen Sie die komplette Vererbungshierarchie der Klasse BufferedOutputStream als UML- Klassendiagramm.
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
2.2 Prozesse in Java
2.2 Prozesse in Java! Java sieht kein Schlüsselwort für Prozesse vor, sondern bestimmte Klassen und Schnittstellen. Mit anderen Worten: der Prozessbegriff wird mit Mitteln der Objektorientierung eingeführt.
Parallele und funktionale Programmierung Wintersemester 2013/ Übung Abgabe bis , 16:00 Uhr
3. Übung Abgabe bis 15.11.2013, 16:00 Uhr Aufgabe 3.1: Sichtbarkeiten a) Aus welchen Gründen ist Sichtbarkeitssynchronisation bei parallelen Programmen wichtig? b) Welche Rollen spielen hierbei das Schlüsselwort
Prozesse. Prozesse sind Programme. Prozesse können aus Unterprozessen bestehen. Prozesshierarchie Unterprozesse Threads
Threads Prozesse, Parallelität, Nebenläufigkeit, Threads, Erzeugung, Ausführung, Kommunikation, Interferenz, Kritischer Bereich, Deadlock, Synchronisation. Prozesse Prozesse sind Programme mehrere Prozesse
Nebenläufige Anwendungen in Java (J2SE, Rich Client, J2EE)
CNAM Wintersemester 2014 / 2015 Nebenläufige Anwendungen in Java (J2SE, Rich Client, J2EE) Im Rahmen von: Betriebssysteme und nebenläufige Anwendungen Agenda Nebenläufigkeit in Java Anwendungen Basisfunktionen
