Überblick. Verteilte Systeme - Übung. Was ist ein Thread? Threads in Java. Multithreading in Java Threads Synchronisation Koordinierung
|
|
|
- Adam Abel
- vor 8 Jahren
- Abrufe
Transkript
1 Ü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 Was ist ein Thread? in Java Aktivitätsträger mit eigenem Ausführungskontext Instruktionszähler Register Stack Alle laufen im gleichen Adressbereich Arbeit auf lokalen Variablen Kommunikation mit anderen 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- 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- werden für Hintergrundaktivitäten genutzt Sobald alle Nicht-Daemon- beendet sind, ist auch das Programm beendet Beachte: Thread-Attribute gehen auf neu erzeugte über Beispiel: Daemon-Thread A mit Priorität 7 erzeugt Thread B Thread B ist Daemon und hat ebenfalls Priorität 7
2 Erzeugung von in Java java.lang.thread Erzeugung von 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 Beispiel 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 Beispiel class RunnableTest implements Runnable { public void run () { System. out. println (" Test "); RunnableTest test = new RunnableTest (); Thread thread = new Thread ( test ); thread. start (); Pausieren von sleep(), yield() Beenden von 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 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.
3 Beenden von join() Veraltete Methoden Auf die Beendigung von anderen warten Mittels join()-methode public void join() throws InterruptedException; Beispiel Runnable worker = new MyWorker (); 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? 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 run() beendet TERMINATED
4 State-of-the-art Ü:,,Warum ist dein Programm nicht synchronisiert? S:,,Die mach ich später! [später...] S:,,Kann ich die nicht einfach weglassen? Ü:,,Nein. [später...] S:,,Ich hab die weggelassen. Es geht trotzdem! Ü:,,Zufall. [Bei der Abgabe...] S:,,Gerade geht s nicht. Aber vorhin hat s funktioniert! Ü:,,Zufall. Was ist zu tun, damit es auch bei der Abgabe funktioniert? sbedarf: Beispiel 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); Probleme mit Multithreading: Beispiel 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 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 dasselbe Sperrobjekt mehrfach halten (rekursive Sperre)
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 Beispiel 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 svarianten (siehe später) synchronized ( this ) { a = a + 1; Wann muss synchronisiert werden? 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 Beispiele: -,,a = a Listen-Operationen (add(), remove(),...) 2. Zusammenhängende Methodenaufrufe müssen atomar erfolgen Methodenfolge muss auf einem konsistenten Zustand arbeiten Beispiel: 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! Synchronisierte Datenstrukturen java.util.collections Die Klasse java.util.collections Idee Statische Wrapper-Methoden für java.util.collection-objekte 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); Beispiel 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 vorherige Folie)
6 alleine nicht ausreichend Jeder Thread,,lebt in seiner eigenen Welt haben keine Möglichkeit sich abzustimmen unterstützt Verwaltung von gemeinsam genutzten Betriebsmitteln Rollenverteilung (z.b. Producer/Consumer) Gemeinsame Behandlung von Problemsituationen... sbedarf: Beispiel in Java Übersicht 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 notwendig Grundprinzip Ein Thread wartet darauf, dass eine Bedingung wahr wird oder ein Ereignis eintritt werden mittels svariablen benachrichtigt Beachte Jedes Java-Objekt kann als svariable dienen Um andere über eine svariable 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
7 in Java Beispiel Explizite Locks java.util.concurrent.locks.lock Beispiel Variablen Object syncobject = new Object (); // Sync.- 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 (); 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 (); ReentrantLock vs. synchronized Bedingungsvariablen java.util.concurrent.locks.condition 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 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)
8 Semaphoren java.util.concurrent.semaphore 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]); Beispiel Semaphore s = new Semaphore (1); s. acquireuninterruptibly (); s. release ();
Überblick. Middleware - Übung. Threads in Java. Was ist ein Thread? Multithreading in Java Threads Synchronisation Koordinierung
Ü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
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
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
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:
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
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
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
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
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
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()
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.
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
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
Ü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)
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
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
Parallele Programmierung in Java
PPJ-1 Parallele Programmierung in Java Prof. Dr. Uwe Kastens Sommersemester 2000 Vorlesung Parallele Programmierung in Java SS 2000 / Folie 01 PPJ-2 Ziele und Durchführung Die Studierenden sollen grundlegende
Multi-Threading. Ralf Abramowitsch Vector Informatik GmbH [email protected]
Multi-Threading Ralf Abramowitsch Vector Informatik GmbH [email protected] Einführung in Threads Threads synchronisieren ThreadPools Thread = unabhängiger Ausführungspfad, der gleichzeitig
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
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,
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
Vorlesung 7. Multithreading in Java 5: Die neuen Concurrency APIs
Vorlesung 7 Multithreading in Java 5: Die neuen Concurrency APIs 1 Die neuen Pakete ÜBERSICHT DER VORLESUNG java.util.concurrent Standardimplementierungen oftmals benötigter Hilfsmittel in nebenläufigen
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
12. Threads in Java. Sequentielle Abarbeitung (2) Beispiel: Thread (1) Sequentielle Abarbeitung (1)
12. Threads in Java Einführendes Beispiel 12. Threads in Java 12. Threads in Java Einführendes Beispiel Sequentielle Abarbeitung (2) Ein Thread ist eine Folge von Anweisungen, die unabhängig von anderen
Java Schulung (Java 2 Java Development Kit 5 / 6)
4. Threads und nebenläufige Programmierung 4.1 Prozesse und Threads Moderne Betriebssysteme geben Benutzer die Illusion, verschiedene Programm würden gleichzeitig ausgeführt (Multitasking) Tatsächlich
Dezentrale Kontrolle: Aktive Objekte. Aktive Objekte Die Klasse AnimatorThread Aktivierung Objekte beobachten Die Java-Klasse Thread
Dezentrale Kontrolle: Aktive Objekte Aktive Objekte Die Klasse AnimatorThread Aktivierung Objekte beobachten Die Java-Klasse Thread Passive Objekte Bieten Dienste auf Abruf an: - eine Zahl von der Konsole
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
Klausur Software-Entwicklung September 00
Aufgabe 1: Wahrheitstafeln ausgeben (ca. 8 Punkte) Matrikelnr : Ergänzen Sie in folgendem Programm, eine rekursive Funktion, die eine Boole'sche Wahrheitstafel für N Variablen ausgibt. Die Zahl N soll
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
3.2 Prozessumschaltung
3.2 Prozessumschaltung (dispatching) deaktiviert einen Prozess und aktiviert einen anderen. Wann? aktiver Prozess wird vom Prozessor verdrängt zugunsten eines bereiten Prozesses aktiver Prozess blockiert,
Das Monitorkonzept Brinch-Hansen
Das Monitorkonzept (nach Hoare/Brinch Brinch-Hansen 1974) Nur ein Prozess bzw. Thread kann zu einem bestimmten Zeitpunkt im Monitor aktiv sein => gegenseitiger Ausschluss, mutual exclusion. Geschützte
Mobile und Verteilte Datenbanken
Mobile und Verteilte Datenbanken Java RMI Vorlesung Wintersemester 2010/2011 [email protected] Institut für Informationssysteme Universität zu Lübeck Java Remote Method Invocation (RMI) Realisierung
6 Speicherorganisation
Der Speicher des Programms ist in verschiedene Speicherbereiche untergliedert Speicherbereiche, die den eigentlichen Programmcode und den Code der Laufzeitbibliothek enthalten; einen Speicherbereich für
Java Threads. Mutex, Race Condition, Deadlock, Starvation und Co.. Prof. Dr. Nikolaus Wulff
Java Threads Mutex, Race Condition, Deadlock, Starvation und Co.. Prof. Dr. Nikolaus Wulff Java Threads Threads sind leichtgewichtige Prozesse. Sie benötigen keine Betriebsystemressourcen wie ein echter
Verteilte Systeme CS5001
Verteilte Systeme CS5001 Th. Letschert TH Mittelhessen Gießen University of Applied Sciences Client-Server-Anwendungen: Vom passiven (shared state) Monitor zum aktiven Monitor Monitor (Hoare, Brinch-Hansen,
Threads In dieser Übung beschäftigen wir uns mit der Realisierung von Threads in Java.
Threads In dieser Übung beschäftigen wir uns mit der Realisierung von Threads in Java. Aufgabe 1: Erzeugen und Starten von Threads a) Sei BankKunde eine von einer Klasse Kunde abgeleitete Klasse. Erweitern
AuD-Tafelübung T-B5b
6. Übung Sichtbarkeiten, Rekursion, Javadoc Di, 29.11.2011 1 Blatt 5 2 OOP Klassen Static vs. Instanzen Sichtbarkeit 3 Stack und Heap Stack Heap 4 Blatt 6 1 Blatt 5 2 OOP Klassen Static vs. Instanzen Sichtbarkeit
Schnittstellen, Stack und Queue
Schnittstellen, Stack und Queue Schnittstelle Stack Realisierungen des Stacks Anwendungen von Stacks Schnittstelle Queue Realisierungen der Queue Anwendungen von Queues Hinweise zum Üben Anmerkung: In
Klausurvorbereitung VS1 (Prof. Brecht) (B0rg Edition)
Ein Prozess kann unmittelbar vom Zustand 1. Running in den Zustand Ready 2. Running in den Zustand Blocked 3. Ready in den Zustand Running Klausurvorbereitung VS1 (Prof. Brecht) (B0rg Edition) Der Adressraum
6. Tutorium zu Softwaretechnik I
6. Tutorium zu Softwaretechnik I Parallelität und Testen Michael Hoff 01.07.2014 INSTITUT FÜR PROGRAMMSTRUKTUREN UND DATENORGANISATION KIT Universität des Landes Baden-Württemberg und nationales Forschungszentrum
Kapitel 5. Monitore und Synchronisationsbedingungen
Seite Kapitel 5 Monitore und Synchronisationsbedingungen Prof. Dr. Rolf Hennicker 5.6.24 5. Synchronisationsbedingungen Seite 2 Bisherige Verwendung von Monitoren: Verkapselung von Daten, Zugriffoperationen
Algorithmen und Programmierung IV: Nichtsequentielle Programmierung. Robert Tolksdorf. Freie Universität Berlin
Algorithmen und Programmierung IV: Nichtsequentielle Programmierung Robert Tolksdorf Freie Universität Berlin Überblick Überblick Sperrsynchronisation Sperrsynchronisation in Datenbanken Bedingungssynchronisation
Mobile und Verteilte Datenbanken
Mobile und Verteilte Datenbanken Java RMI Vorlesung Wintersemester 2013/2014 [email protected] Institut für Informationssysteme Universität zu Lübeck Kommunikations-Middleware Bietet höhere Kommunikations-Dienste
Einstieg in die Informatik mit Java
1 / 15 Einstieg in die Informatik mit Java Collections Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 15 1 Überblick Collections 2 Hierarchie von Collections 3 Verwendung
Java RMI Remote Method Invocation
Java RMI Remote Method Invocation Ziel: Aufruf von Instanzmethoden entfernter Objekte basierend auf Java. Paket: java.rmi und Unterpakete Topologie: RMI Registry RMI Server RMI Client Der Server registriert
Nebenläufigkeit in Java
Nebenläufigkeit in Java Maurice Schoenmakers [email protected] muenchen.de Inhaltsverzeichnis 1 Einleitung... 2 2 Prozesse und Threads in Java... 2 2.1 Die Klasse Thread... 3 2.2 Der aktuelle Thread...
Nebenläufige Programmierung I
Nebenläufige Programmierung I Martin Wirsing in Zusammenarbeit mit Matthias Hölzl, Piotr Kosiuczenko, Dirk Pattinson 07/03 Ziele 2 Grundlegende Begriffe der nebenläufigen Programmierung verstehen lernen
Synchronisation von Variablen und Operationen (gemeinsamer Speicher)
Synchronisation von Variablen und Operationen (gemeinsamer Speicher) Vorbemerkung Beispiel für Wettlaufbedingungen Threadsicherheit Unveränderliche Objekte Volatile-Deklaration Atomare Operationen Lock-Mechanismen
Arbeitsblätter für die Lehrveranstaltung OOP JAVA 1
Fachhochschule Stralsund Fachbereich Maschinenbau Lehrgebiet Informatik Prof. Dr.-Ing. Ch.Wahmkow Arbeitsblätter für die Lehrveranstaltung OOP I. Aufbau eines Java-Programmes JAVA 1 Escape-Sequenzen zur
7. Objektorientierte Softwareentwicklung/3. Informatik II für Verkehrsingenieure
7. Objektorientierte Softwareentwicklung/3 Informatik II für Verkehrsingenieure Überblick FOLGENDE BEGRIFFE/PRINZIPIEN SOLLTEN BEKANNT SEIN Objekte Klasse Attribute Fähigkeiten ZIEL DER HEUTIGEN LEHRVERANSTALTUNG
Objektorientierte Programmierung OOP Objektorientierte Programmierung (OOP) mit Java
9 Übungen: Applets Objektorientierte Programmierung OOP Objektorientierte Programmierung (OOP) mit Java 1. Java-Applet mit Text 2. Java-Applet mit Bild und Text 3. Java-Applet mit Grafik 9 Applets 4. Java-Applet
Nebenläufige und verteilte Programme CS2301
Nebenläufige und verteilte Programme CS2301 Th. Letschert TH Mittelhessen Gießen University of Applied Sciences Netze mit aktiven und reaktiven Knoten Produzent Konsument: aktiv / passiv / reaktiv
Java-Programmierung. Remote Method Invocation - RMI
Java-Programmierung Remote Method Invocation - RMI Entwicklungsmethoden Sockets Entwurf verteilter Anwendungen ist relativ aufwändig, da zunächst ein Kommunikationsprotokoll entwickelt werden muss aufwändig
Prinzipien Objektorientierter Programmierung
Prinzipien Objektorientierter Programmierung Valerian Wintner Inhaltsverzeichnis 1 Vorwort 1 2 Kapselung 1 3 Polymorphie 2 3.1 Dynamische Polymorphie...................... 2 3.2 Statische Polymorphie........................
1 Polymorphie (Vielgestaltigkeit)
1 Polymorphie (Vielgestaltigkeit) Problem: Unsere Datenstrukturen List, Stack und Queue können einzig und allein int-werte aufnehmen. Wollen wir String-Objekte, andere Arten von Zahlen oder andere Objekttypen
Universität Augsburg, Institut für Informatik Sommersemester 2003 Prof. Dr. Bernhard Bauer 18. Oktober 2003 Stefan Fischer, Dr.
Universität Augsburg, Institut für Informatik Sommersemester 2003 Prof. Dr. Bernhard Bauer 18. Oktober 2003 Stefan Fischer, Dr. Martin Müller Informatik II 2. Semesterklausur Prüfungsmodul Informatik II
Kapitel 9. Programmierkurs. Attribute von Klassen, Methoden und Variablen. 9.1 Attribute von Klassen, Methoden und Variablen
Kapitel 9 Programmierkurs Birgit Engels Anna Schulze Zentrum für Angewandte Informatik Köln Objektorientierte Programmierung Attribute von Klassen, Methoden und Variablen Interfaces WS 07/08 1/ 18 2/ 18
UML / Fujaba. Generierung von Java-Quellcode aus UML-Diagrammen. Marcel Friedrich
UML / Fujaba Generierung von Java-Quellcode aus UML-Diagrammen Marcel Friedrich Agenda Einleitung Struktur Verhalten Klassendiagramme Storydiagramme Statecharts Action methods 2 Thema Codegenerierung mit
Übung 1 mit C# 6.0 MATTHIAS RONCORONI
Übung 1 mit C# 6.0 MATTHIAS RONCORONI Inhalt 2 1. Überblick über C# 2. Lösung der Übung 1 3. Code 4. Demo C# allgemein 3 aktuell: C# 6.0 mit.net-framework 4.6: Multiparadigmatisch (Strukturiert, Objektorientiert,
Einstieg in die Informatik mit Java
1 / 25 Einstieg in die Informatik mit Java Objektorientierte Programmierung und Klassen Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 25 1 Die Philosophie 2 Definition
3 Objektorientierte Konzepte in Java
3 Objektorientierte Konzepte in Java Bisherige Beobachtungen zu Objekten: werden in Klassen zusammengefasst besitzen Eigenschaften und Verhalten verbergen private Informationen werden geboren, leben und
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
1 Fehler-Objekte: Werfen, Fangen, Behandeln
1 Fehler-Objekte: Werfen, Fangen, Behandeln Tritt während der Programm-Ausführung ein Fehler auf, wird die normale Programm-ausführung abgebrochen und ein Fehler-Objekt erzeugt (geworfen). Die Klasse Throwable
Kapitel 4. Monitore und wechselseitiger Ausschluss
Seite 1 Kapitel 4 Monitore und wechselseitiger Ausschluss Prof. Dr. Rolf Hennicker 28.05.2015 4.1 Interferenzen Seite 2 Parallel ablaufende Prozesse können sich gegenseitig (störend) beeinflussen. Beispiel
#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)
II. Grundlagen der Programmierung. 9. Datenstrukturen. Daten zusammenfassen. In Java (Forts.): In Java:
Technische Informatik für Ingenieure (TIfI) WS 2005/2006, Vorlesung 9 II. Grundlagen der Programmierung Ekkart Kindler Funktionen und Prozeduren Datenstrukturen 9. Datenstrukturen Daten zusammenfassen
Einführung in die Informatik
Einführung in die Informatik Jochen Hoenicke Software Engineering Albert-Ludwigs-University Freiburg Sommersemester 2014 Jochen Hoenicke (Software Engineering) Einführung in die Informatik Sommersemester
Javakurs FSS Lehrstuhl Stuckenschmidt. Tag 3 - Objektorientierung
Javakurs FSS 2012 Lehrstuhl Stuckenschmidt Tag 3 - Objektorientierung Warum Objektorientierung Daten und Funktionen möglichst eng koppeln und nach außen kapseln Komplexität der Software besser modellieren
3 Objektorientierte Konzepte in Java
3 Objektorientierte Konzepte in Java 3.1 Klassendeklarationen Fragen an die Klassendeklaration: Wie heißt die Klasse? Wer darf auf die Klasse und ihre Attribute/Methoden zugreifen? Ist die Klasse eine
Java Einführung Collections
Java Einführung Collections Inhalt dieser Einheit Behälterklassen, die in der Java API bereitgestellt werden Wiederholung Array Collections (Vector, List, Set) Map 2 Wiederholung Array a[0] a[1] a[2] a[3]...
1 Organisatorisches. 2 Compilezeit- und Laufzeitfehler. 3 Exceptions. 4 Try-Catch-Finally
Themen der Übung CoMa-Übung VI 1 Organisatorisches Compilezeit- und Laufzeitfehler 3 Try-Catch-Finally TU Berlin 8.11.01 Bewertung der OA 5 fehlerhaft, Madeleine arbeitet dran CoMa-Übung VI (TU Berlin)
Klausur: Java (Liste P)
Klausur: Java (Liste P) SS05 Erlaubte Hilfsmittel: Gebundene! Unterlagen (Skript mit Anmerkungen, eigene Mitschrift) und maximal ein Buch. Bitte keine losen Blätter. Lösung ist auf den Klausurbögen anzufertigen.
Domänenmodell: Fadenkommunikation und -synchronisation
Domänenmodell: Fadenkommunikation und -synchronisation Alexander Humphreys, Reinhard Rösch, Fabian Scheler 15. Mai 2003 Inhaltsverzeichnis 1 Domänendefinition 1 2 Domänenlexikon 1 3 Konzeptmodelle 4 4
Nebenläufige Programmierung I
Nebenläufige Programmierung I Martin Wirsing in Zusammenarbeit mit Moritz Hammer und Axel Rauschmayer SS06 2 Ziele Grundlegende Begriffe der nebenläufigen Programmierung verstehen lernen Nebenläufige Programme
System.out.println("TEXT");
Inhaltsübersicht - Erstes Beispiel - Datentypen - Ausdrücke und Operatoren - Schleifen / Bedinungen - Struktogramme - Grundgerüst eines Programms in JAVA - Einlesen von Daten Erstes Beispiel public class
Gebundene Typparameter
Gebundene Typparameter interface StringHashable { String hashcode(); class StringHashMap { public void put (Key k, Value v) { String hash = k.hashcode();...... Objektorientierte
Javadoc. Programmiermethodik. Eva Zangerle Universität Innsbruck
Javadoc Programmiermethodik Eva Zangerle Universität Innsbruck Überblick Einführung Java Ein erster Überblick Objektorientierung Vererbung und Polymorphismus Ausnahmebehandlung Pakete und Javadoc Spezielle
Theorie zu Übung 8 Implementierung in Java
Universität Stuttgart Institut für Automatisierungstechnik und Softwaresysteme Prof. Dr.-Ing. M. Weyrich Theorie zu Übung 8 Implementierung in Java Klasse in Java Die Klasse wird durch das class-konzept
Nebenläufige Programmierung in Java
Informatik IV 37-004 SS 2002 Thomas Gross Diese Slides kommen ohne Gewähr. 9-1 Thomas Gross 1997-2000 Nebenläufige Programmierung in Java Threads und deren Zustände Speichermodell Einfache Synchronisation
Objektorientierte Programmierung
Universität der Bundeswehr Fakultät für Informatik Institut 2 Priv.-Doz. Dr. Lothar Schmitz FT 2006 Zusatzaufgaben Lösungsvorschlag Objektorientierte Programmierung Lösung 22 (Java und UML-Klassendiagramm)
! 1. Rekursive Algorithmen.! 2. Rekursive (dynamische) Datenstrukturen. II.3.2 Rekursive Datenstrukturen - 1 -
! 1. Rekursive Algorithmen! 2. Rekursive (dynamische) Datenstrukturen II.3.2 Rekursive Datenstrukturen - 1 - Ausdruck Ausdruck Grundwert ( Typ ) Präfix-Operator Name Methodenaufruf [ Ausdruck ] ( Ausdruck
Vorname: Nachname: Matrikelnummer: Klausur. Betriebssysteme
Vorname: Nachname: Matrikelnummer: Klausur Betriebssysteme 12.02.2013 Hinweise: 1. Beschriften Sie als erstes diese Seite mit Ihrem Namen, Vornamen und Ihrer Matrikelnummer (deutlich in Druckbuchstaben).
Kapitel 6. Vererbung
1 Kapitel 6 2 Ziele Das sprinzip der objektorientierten Programmierung verstehen Und in Java umsetzen können Insbesondere folgende Begriffe verstehen und anwenden können: Ober/Unterklassen Subtyping Überschreiben
Musterlösung Stand: 5. Februar 2009
Fakultät IV Elektrotechnik/Informatik Probeklausur Einführung in die Informatik I Hinweis: Diese Probeklausur ist eine kleine Aufgabensammlung, die etwa dem Schwierigkeitsgrad der Teilleistung TL 2 (Programmiertest)
Java für Computerlinguisten
Java für Computerlinguisten 2. Objektorientierte Programmierung Christian Scheible Institut für Maschinelle Sprachverarbeitung 28. Juli 2009 Christian Scheible Java für Computerlinguisten 28. Juli 2009
Allgemeine Informatik II SS :30-13:30 Uhr
TU Darmstadt FB Informatik Prof. J. Fürnkranz Vordiplomsklausur - Lösungsvorschlag Allgemeine Informatik II SS 2005 15.09.2005 11:30-13:30 Uhr Hinweise: Als Hilfsmittel ist nur ein schwarzer oder blauer
Einstieg in die Informatik mit Java
1 / 16 Einstieg in die Informatik mit Java Innere Klassen Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 16 1 Einführung 2 Element-Klassen 3 Lokale Klassen 4 Anonyme Klassen
Kapitel 6. Vererbung
1 Kapitel 6 2 Ziele Das sprinzip der objektorientierten Programmierung verstehen Und in Java umsetzen können Insbesondere folgende Begriffe verstehen und anwenden können: Ober/Unterklassen Subtyping Überschreiben
