我很难理解内部类线程的行为。
我有这个简单的测试程序。
public class Test {
private static Random rand = new Random(System.currentTimeMillis());
public class TestThread extends Thread {
@Override
public void start() {
System.out.println("in start " + Thread.currentThread().getName());
try {
Thread.sleep(rand.nextInt(5000));
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public static void main(String[] args){
System.out.println(Thread.currentThread().getName());
for(int i = 0; i < 5; ++i){
new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(rand.nextInt(5000));
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName());
}
}).start();
}
System.out.println("new run");
Test test = new Test();
for(int i = 0; i < 5; ++i){
(test. new TestThread()).start();
}
}
}
当第一个for循环运行时,线程的行为符合我的预期。共有6个线程,主线程,线程0,线程1,线程2,线程3和线程4。线程0-4的打印顺序不正确。
第二for循环的结果让我感到困惑。
system.out.println("in start " + Thread.currentThread().getName());
它总是打印出“ main”,并且线程是按顺序执行的。为什么内部类线程的执行由主线程执行?
谢谢!
最佳答案
不要覆盖Thread.start()
。始终从启动它的线程中调用start方法。您需要覆盖Thread.run()
。
(请参见Thread
class' javadoc documentation中的示例)
关于java - 为什么扩展线程的内部类的执行线程是主线程?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/33415714/