2007-07-04 16:27:08 -06:00
|
|
|
package java.lang;
|
|
|
|
|
2007-07-21 14:44:39 -06:00
|
|
|
import java.util.Map;
|
|
|
|
import java.util.WeakHashMap;
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
public class Thread implements Runnable {
|
2007-07-28 10:55:24 -06:00
|
|
|
private long peer;
|
2007-07-04 16:27:08 -06:00
|
|
|
private final Runnable task;
|
2007-07-21 14:44:39 -06:00
|
|
|
private Map<ThreadLocal, Object> locals;
|
2007-07-28 10:55:24 -06:00
|
|
|
private boolean interrupted;
|
2007-07-28 15:28:25 -06:00
|
|
|
private Object sleepLock;
|
2007-07-31 18:08:20 -06:00
|
|
|
private ClassLoader classLoader;
|
2007-07-04 16:27:08 -06:00
|
|
|
|
|
|
|
public Thread(Runnable task) {
|
|
|
|
this.task = task;
|
2007-07-28 15:28:25 -06:00
|
|
|
|
2007-07-31 18:08:20 -06:00
|
|
|
Thread current = currentThread();
|
|
|
|
|
|
|
|
Map<ThreadLocal, Object> map = current.locals;
|
2007-07-21 16:36:51 -06:00
|
|
|
if (map != null) {
|
|
|
|
for (Map.Entry<ThreadLocal, Object> e: map.entrySet()) {
|
|
|
|
if (e.getKey() instanceof InheritableThreadLocal) {
|
2007-07-28 10:10:13 -06:00
|
|
|
InheritableThreadLocal itl = (InheritableThreadLocal) e.getKey();
|
|
|
|
locals().put(itl, itl.childValue(e.getValue()));
|
2007-07-21 16:36:51 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2007-07-31 18:08:20 -06:00
|
|
|
|
|
|
|
classLoader = current.classLoader;
|
2007-07-29 19:27:42 -06:00
|
|
|
}
|
2007-07-21 16:36:51 -06:00
|
|
|
|
2007-11-06 17:41:53 -07:00
|
|
|
public Thread(Runnable task, String name) {
|
|
|
|
this(task);
|
|
|
|
}
|
|
|
|
|
2007-07-29 19:27:42 -06:00
|
|
|
public synchronized void start() {
|
|
|
|
if (peer != 0) {
|
|
|
|
throw new IllegalStateException("thread already started");
|
|
|
|
}
|
|
|
|
|
|
|
|
peer = doStart();
|
|
|
|
if (peer == 0) {
|
|
|
|
throw new RuntimeException("unable to start native thread");
|
|
|
|
}
|
2007-07-21 16:36:51 -06:00
|
|
|
}
|
|
|
|
|
2007-07-29 19:27:42 -06:00
|
|
|
private native long doStart();
|
2007-07-04 16:27:08 -06:00
|
|
|
|
|
|
|
public void run() {
|
|
|
|
if (task != null) {
|
|
|
|
task.run();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-31 18:08:20 -06:00
|
|
|
public ClassLoader getContextClassLoader() {
|
|
|
|
return classLoader;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setContextClassLoader(ClassLoader v) {
|
|
|
|
classLoader = v;
|
|
|
|
}
|
|
|
|
|
2007-07-21 14:44:39 -06:00
|
|
|
public Map<ThreadLocal, Object> locals() {
|
|
|
|
if (locals == null) {
|
|
|
|
locals = new WeakHashMap();
|
|
|
|
}
|
|
|
|
return locals;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static native Thread currentThread();
|
|
|
|
|
2007-07-28 15:28:25 -06:00
|
|
|
private static native void interrupt(long peer);
|
|
|
|
|
|
|
|
public synchronized void interrupt() {
|
|
|
|
if (peer != 0) {
|
|
|
|
interrupt(peer);
|
|
|
|
} else {
|
|
|
|
interrupted = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static boolean interrupted() {
|
|
|
|
Thread t = currentThread();
|
|
|
|
|
|
|
|
synchronized (t) {
|
|
|
|
boolean v = t.interrupted;
|
|
|
|
t.interrupted = false;
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-28 10:10:13 -06:00
|
|
|
public static void sleep(long milliseconds) throws InterruptedException {
|
|
|
|
Thread t = currentThread();
|
|
|
|
if (t.sleepLock == null) {
|
|
|
|
t.sleepLock = new Object();
|
|
|
|
}
|
|
|
|
synchronized (t.sleepLock) {
|
|
|
|
t.sleepLock.wait(milliseconds);
|
|
|
|
}
|
|
|
|
}
|
2007-07-04 16:27:08 -06:00
|
|
|
}
|