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

持续更新
当我们使用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());
    }
}

结果如图:这里写图片描述
至于原因,我想不用说也能想清楚了吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值