创建线程的两种传统方式
(1)创建Thread的子类,重写run方法
在Thread子类覆盖的run方法中编写运行代码。
(2)给Thread类传入Runnable接口
在传递给Thread对象的Runnable对象的run方法中编写代码。
那我们如果同时重写Thread类和Runnable接口的run方法,上面执行的run方法到底是Runnable的还是Thread的呢?
我们还是给Thread类传入Runnable接口,但是重写Thread类和Runnable接口的run方法,
看看最后执行哪一个:
结果:
Thread Runing in Parent Thread...
总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread
对象的run()方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个
Runnable对象,该run方法会调用Runnable对象的run方法。
即是先运行的Thread对象的run方法,如果Thread对象没有重写run方法,就去运行Runnable的run方法。
两种方式的区别:
给Thread类传入Runnable接口可以实现数据共享,而且更偏向于面向对象的编程思想,所以
使用第二种比较多。
转载请注明出处:http://blog.csdn.net/acmman/article/details/52639243
(1)创建Thread的子类,重写run方法
在Thread子类覆盖的run方法中编写运行代码。
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(){
@Override
public void run() {
System.out.println("Thread Runing...");
super.run();
}
}.start();
}
}
(2)给Thread类传入Runnable接口
在传递给Thread对象的Runnable对象的run方法中编写代码。
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(new Runnable(){
public void run() {
System.out.println("Thread Runing...");
}
}).start();
}
}
那我们如果同时重写Thread类和Runnable接口的run方法,上面执行的run方法到底是Runnable的还是Thread的呢?
我们还是给Thread类传入Runnable接口,但是重写Thread类和Runnable接口的run方法,
看看最后执行哪一个:
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(new Runnable(){
public void run() {
System.out.println("Thread Runing in Runnable...");
}
}){
public void run() {
System.out.println("Thread Runing in Parent Thread...");
}
}.start();
}
}
结果:
Thread Runing in Parent Thread...
总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread
对象的run()方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个
Runnable对象,该run方法会调用Runnable对象的run方法。
即是先运行的Thread对象的run方法,如果Thread对象没有重写run方法,就去运行Runnable的run方法。
两种方式的区别:
给Thread类传入Runnable接口可以实现数据共享,而且更偏向于面向对象的编程思想,所以
使用第二种比较多。
转载请注明出处:http://blog.csdn.net/acmman/article/details/52639243