我很难理解内部类线程的行为。

我有这个简单的测试程序。

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/

10-11 22:22
查看更多