diff --git a/VL04_09/ThreadsMonitor2/.classpath b/VL04_09/ThreadsMonitor2/.classpath new file mode 100644 index 0000000000000000000000000000000000000000..fceb4801b5ffa0e4a68c2b00441e45bf2eefdbed --- /dev/null +++ b/VL04_09/ThreadsMonitor2/.classpath @@ -0,0 +1,6 @@ +<?xml version="1.0" encoding="UTF-8"?> +<classpath> + <classpathentry kind="src" path="src"/> + <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8"/> + <classpathentry kind="output" path="bin"/> +</classpath> diff --git a/VL04_09/ThreadsMonitor2/.gitignore b/VL04_09/ThreadsMonitor2/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..ae3c1726048cd06b9a143e0376ed46dd9b9a8d53 --- /dev/null +++ b/VL04_09/ThreadsMonitor2/.gitignore @@ -0,0 +1 @@ +/bin/ diff --git a/VL04_09/ThreadsMonitor2/.project b/VL04_09/ThreadsMonitor2/.project new file mode 100644 index 0000000000000000000000000000000000000000..df49c092b25ae6bed8d359f047678bebab759f6f --- /dev/null +++ b/VL04_09/ThreadsMonitor2/.project @@ -0,0 +1,17 @@ +<?xml version="1.0" encoding="UTF-8"?> +<projectDescription> + <name>ThreadsMonitor2</name> + <comment></comment> + <projects> + </projects> + <buildSpec> + <buildCommand> + <name>org.eclipse.jdt.core.javabuilder</name> + <arguments> + </arguments> + </buildCommand> + </buildSpec> + <natures> + <nature>org.eclipse.jdt.core.javanature</nature> + </natures> +</projectDescription> diff --git a/VL04_09/ThreadsMonitor2/.settings/org.eclipse.jdt.core.prefs b/VL04_09/ThreadsMonitor2/.settings/org.eclipse.jdt.core.prefs new file mode 100644 index 0000000000000000000000000000000000000000..3a21537071bf4118b9e1ee864cb4bc258aa48211 --- /dev/null +++ b/VL04_09/ThreadsMonitor2/.settings/org.eclipse.jdt.core.prefs @@ -0,0 +1,11 @@ +eclipse.preferences.version=1 +org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled +org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve +org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.debug.lineNumber=generate +org.eclipse.jdt.core.compiler.debug.localVariable=generate +org.eclipse.jdt.core.compiler.debug.sourceFile=generate +org.eclipse.jdt.core.compiler.problem.assertIdentifier=error +org.eclipse.jdt.core.compiler.problem.enumIdentifier=error +org.eclipse.jdt.core.compiler.source=1.8 diff --git a/VL04_09/ThreadsMonitor2/src/inf3/Thread_TextAusgabe.java b/VL04_09/ThreadsMonitor2/src/inf3/Thread_TextAusgabe.java new file mode 100644 index 0000000000000000000000000000000000000000..d326d8566e0b7beacdd72edf1fb5639c89edb685 --- /dev/null +++ b/VL04_09/ThreadsMonitor2/src/inf3/Thread_TextAusgabe.java @@ -0,0 +1,42 @@ +package inf3; +public class Thread_TextAusgabe extends Thread { + char c; + Object consoleLock; + Thread_TextAusgabe (char c, Object consoleLock) { + this.c = c; + this.consoleLock = consoleLock; + } + + void SchreibeZeile (char c) { + for (int ii=0; ii< 20; ii++) { + System.out.print(c + " "); + //busy waiting ... keine gute Idee! +// for (int ll=0; ll< 1000000; ll++) { +// Double kk = Math.sqrt(ll); +// } + try { + Thread.sleep(20); + } catch (InterruptedException e) { + System.out.println("interrupted while sleeping"); + } + } + System.out.println(); + } + + public void run() { + synchronized (consoleLock) { + for (int ii=0; ii<5; ii++) { + SchreibeZeile(c); + consoleLock.notifyAll(); + try { + consoleLock.wait(); + } catch (InterruptedException e) { + ; + } + } + consoleLock.notifyAll(); + } + } +} + + diff --git a/VL04_09/ThreadsMonitor2/src/inf3/ThreadsMonitor2.java b/VL04_09/ThreadsMonitor2/src/inf3/ThreadsMonitor2.java new file mode 100644 index 0000000000000000000000000000000000000000..0fff6498bc9d76d73bf187d74275f0982dc07692 --- /dev/null +++ b/VL04_09/ThreadsMonitor2/src/inf3/ThreadsMonitor2.java @@ -0,0 +1,33 @@ +/** Programm zur Demonstration der Threadsynchronisation + * durch den Einsatz eines Monitors: Zwei Threads sollen + * jeweils 10 mal die im Konstruktor übergebene Ziffer in eine + * Zeile schreiben. + * + * Durch Verwendung der Methoden wait() und notify() zusamen mit + * einem gemeinsam genutzten Lock-Objekt kann erzwungen werden, dass + * sich die Threads bei der Textausgabe abwechseln. + * + * @author stedS + * @version 1.0 (2021-01-25) + */ +package inf3; +public class ThreadsMonitor2 { + char c; + + public static void main(String[] args) { + Object console = new Object(); + Thread_TextAusgabe th1 = new Thread_TextAusgabe('1', console); + Thread_TextAusgabe th2 = new Thread_TextAusgabe('2', console); + th1.start(); + th2.start(); + try { + th1.join(); + th2.join(); + } catch (InterruptedException e) { + System.out.println("join interrupted"); + } + System.out.println("Programmende"); + } +} + +