您的位置:首页 > 编程语言 > Java开发

Java多线程之Thread的run()与start()方法解析

2017-03-03 17:38 691 查看
持续更新

当我们使用Thread类来创建线程后,总是通过调用实例方法start()来启动线程,而线程在启动后一旦被线程调度器调度便会执行run()方法。那么问题来了,如果直接使用Thread实例调用run()方法,此时的执行线程会是谁呢?(主线程main or 子线程)。不妨来测试一番:

public class Test{
public static void main(String[] args) {
MyThread mt = new MyThread();

mt.run();
mt.start();
}
}
class MyThread extends Thread {
@Override
public void run() {
//此处不直接调用实例方法getName()来获取线程名,原因请看下文
System.out.println("Current thread --- " + Thread.currentThread().getName());
}
}


执行结果:


Ok,现在来解释为什么直接调用run()方法时,执行线程是main:

实例mt是一个Thread实例没错,但是只有当执行mt.start()后,JVM会启动一个与之相对应的线程。换句话说,mt只有在调用了start()方法后,才会被当作线程对象处理。如果直接调用run()方法,系统会把线程对象mt当作普通对象处理,run()方法就是一个普通方法。因此,要正确获取调用run()方法的线程名不能直接调用实例方法getName(),而应使用类方法获取线程后在获取线程名。

思考:通过实现Runnable接口的类,其实例直接调用run()方法与作为Thread的target参数的Thread实例调用run()方法会怎样?

此处给出代码:

public class Test{
public static void main(String[] args) {
MyRun mr = new MyRun();
Thread t = new Thread(mr);

mr.run();
t.run();
t.start();
}
}
class MyRun implements Runnable {
@Override
public void run() {
System.out.println("Thread name in run : " + Thread.currentThread().getName());
}
}


结果如图:


至于原因,我想不用说也能想清楚了吧!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐