黑马程序员技术交流社区

标题: 大家帮忙看看这个异常问题, [打印本页]

作者: darkpiece    时间: 2014-3-9 16:06
标题: 大家帮忙看看这个异常问题,
本帖最后由 darkpiece 于 2014-3-9 18:13 编辑

public class ThreadTest {
        public static void main(String args[]) {
        MyThread t = new MyThread();
        t.run();
        t.start();
        System.out.println("A");
        }
    }

    class MyThread extends Thread {
        public void run() {
            try {
                Thread.sleep(3000);
                } catch (InterruptedException e) {
             }
            System.out.println("B");
            }
    }

输出结果是什么?多线程异常有点拿不准!不知道睡3秒 a先走还是b先走?
作者: volvoxc    时间: 2014-3-9 16:37
打印结果BAB。首先主线程调用t对象的run方法,这个就是普通的方法调用,程序就只有一个主线程在运行,在run方法里,主线程等待三秒钟打印"B".run方法执行结束,主线程继续往下执行,调用t的start方法,这时主线程就又开启了一个新的线程去执行run方法里的代码,同时,主线下继续往下执行,打印"A",主线程结束,在run方法里的线程等待三秒后打印"B",此线程也结束,整个程序结束。
作者: darkpiece    时间: 2014-3-9 17:44
volvoxc 发表于 2014-3-9 16:37
打印结果BAB。首先主线程调用t对象的run方法,这个就是普通的方法调用,程序就只有一个主线程在运行,在run ...

原来如此 ,清晰明了。谢了




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2