使用两种方式考虑以下问题:
1、为什么调用start()方法就可以启动线程,而不是调用run()?
答:在new一个线程对象后直接调用run方法,只是让当前线程去执行run()方法中的语句,并没有实现多线程;而start()方法调用 start0() 去告诉操作系统创建线程,线程创建完成后,等待CPU分配时间片来执行run()方法,异步。
2、在Runnable层面实现run()方法和Thread层面实现run()方法的区别。
@Override public void run() { if (target != null) { target.run(); } }
target 为Runnable接口的实例化对象,由Thread构造函数Thread(Runnable target)等传入赋值的
1、如果我们选择创建一个类继承Thread,然后重写run()方法,原先的run()方法被子类重写的run()方法覆盖,原先run()方法中的 target.run();不可能被调用,线程对象调用start()方法后运行的是重写后的run()方法中的内容。
2、如果我们实例化Runnable对象,重写它的run()方法(注意哦!这里的run()方法不是Thread类中的run()方法),然后
在创建Thread对象的时候把它传入,接下来用Thread对象调用start()方法执行的就是target.run(),也就是Runnable实例化后重写的run()方法的方法体了。
3、如果在传入Runnable实例化对象后又重写了Thread类的run()方法,最终调用的是Thread类中重写的run()方法。
————————————————
参考链接:https://blog.csdn.net/mayifan_blog/article/details/85794988