Wolfgang Thaller aaf905ce07 add gcc 4.70
2012-03-28 01:13:14 +02:00

35 lines
840 B
Java

// Test atomic increment via synchronized blocks.
public class SyncTest implements Runnable {
static int counter;
public void run() {
// We cache the .class value; otherwise this code is
// slow enough that it will time out in some situations.
Object lock = SyncTest.class;
for (int n = 0; n < 1000000; n++)
synchronized (lock) {
counter++;
}
}
public static void main(String[] args) {
SyncTest test = new SyncTest();
Thread[] thr = new Thread[4];
for (int n = 0; n < thr.length; n++) {
thr[n] = new Thread(test);
thr[n].start();
}
for (int n = 0; n < thr.length; n++) {
try {
thr[n].join();
} catch (InterruptedException ex) {
}
}
System.out.println(counter == 1000000 * thr.length ?
"ok" : "fail: " + counter);
}
}