corda/test/Threads.java

45 lines
1.1 KiB
Java
Raw Normal View History

public class Threads implements Runnable {
2007-07-01 22:04:03 -06:00
public static void main(String[] args) {
Threads test = new Threads();
2007-07-07 12:09:16 -06:00
Thread thread = new Thread(test);
2007-07-01 22:04:03 -06:00
try {
synchronized (test) {
2007-07-07 12:09:16 -06:00
thread.start();
2007-07-01 22:04:03 -06:00
test.wait();
}
} catch (Throwable e) {
e.printStackTrace();
}
System.out.println("finished");
}
public void run() {
synchronized (this) {
int i = 0;
try {
2007-07-10 19:38:06 -06:00
System.out.println("I'm running in a separate thread!");
2007-07-01 22:04:03 -06:00
2007-07-10 22:19:26 -06:00
final int arrayCount = 16;
final int arraySize = 4;
System.out.println("Allocating and discarding " + arrayCount +
" arrays of " + arraySize + "MB each");
for (; i < arrayCount; ++i) {
byte[] array = new byte[arraySize * 1024 * 1024];
}
2007-07-01 22:04:03 -06:00
long nap = 5;
System.out.println("sleeping for " + nap + " seconds");
Thread.sleep(nap * 1000);
} catch (Throwable e) {
System.err.println("caught something in second thread after " + i +
" iterations");
e.printStackTrace();
} finally {
notifyAll();
}
}
}
}