Merge pull request #122 from shannah/add_thread_join

Implemented Thread.join()
This commit is contained in:
Alexey Andreev 2015-06-05 17:04:13 +03:00
commit 2e2ab98e38

View File

@ -36,7 +36,9 @@ public class TThread extends TObject implements TRunnable {
private int priority = 0; private int priority = 0;
private long timeSliceStart; private long timeSliceStart;
private int yieldCount; private int yieldCount;
private final Object finishedLock = new Object();
private TString name; private TString name;
TRunnable target; TRunnable target;
@ -90,6 +92,9 @@ public class TThread extends TObject implements TRunnable {
if (target != null) { if (target != null) {
target.run(); target.run();
} }
synchronized(finishedLock) {
finishedLock.notifyAll();
}
} }
public static TThread currentThread() { public static TThread currentThread() {
@ -99,6 +104,23 @@ public class TThread extends TObject implements TRunnable {
public TString getName() { public TString getName() {
return name; return name;
} }
public final void join(long millis, int nanos) throws InterruptedException {
if (currentThread() == this) {
return;
}
synchronized(finishedLock) {
finishedLock.wait(millis, nanos);
}
}
public final void join(long millis) throws InterruptedException {
join(millis, 0);
}
public final void join() throws InterruptedException {
join(0);
}
public static void yield() { public static void yield() {
TThread currentThread = currentThread(); TThread currentThread = currentThread();