From e5fe93a0ad089579bdc0e22ce73bd1f74aa0ec08 Mon Sep 17 00:00:00 2001 From: aph Date: Mon, 12 Jun 2006 13:37:54 +0000 Subject: 2006-06-12 Andrew Haley * testsuite/libjava.lang/PR27908.out: New. * testsuite/libjava.lang/PR27908.java: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@114568 138bc75d-0d04-0410-961f-82ee72b054a4 --- libjava/testsuite/libjava.lang/PR27908.java | 80 +++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 libjava/testsuite/libjava.lang/PR27908.java (limited to 'libjava/testsuite/libjava.lang/PR27908.java') diff --git a/libjava/testsuite/libjava.lang/PR27908.java b/libjava/testsuite/libjava.lang/PR27908.java new file mode 100644 index 00000000000..66e7fca02ed --- /dev/null +++ b/libjava/testsuite/libjava.lang/PR27908.java @@ -0,0 +1,80 @@ +class PR27908 +{ + public static void main (String[] argv) + { + run1 r1 = new run1(); + run2 r2 = new run2(); + run3 r3 = new run3(); + + new Thread (r1).start(); + new Thread (r2).start(); + new Thread (r3).start(); + + Thread.yield(); + + r1.stop(); + r2.stop(); + r3.stop(); + } + + private static class run1 implements Runnable + { + volatile int counter; + volatile boolean running; + + public void run () + { + counter = 0; + running = true; + while (running) + counter++; + System.out.println ("run1 exits!"); + } + + private void stop () + { + running = false; + } + } + + private static class run2 implements Runnable + { + volatile int counter; + boolean running; + + public void run () + { + counter = 0; + running = true; + while (running) + counter++; + System.out.println ("run2 exits!"); + } + + private void stop () + { + running = false; + } + } + + static class run3 implements Runnable + { + volatile int counter; + private volatile boolean running; + + public void run () + { + counter = 0; + running = true; + while (running) + counter++; + System.out.println ("run3 exits!"); + } + + void stop () + { + running = false; + } + } + +} -- cgit v1.2.3