Thread和Runnable的子类调用


实现线程的两种方式:
继承Thread类。
实现Runnable接口。


下面是一个小案例:


public class ThreadRunnable {
public static void main(String[] args) {
Runnable mr = new MyRunnable();
Thread mt = new Mythread(mr);
mt.start();
}
}
class Mythread extends Thread{
public Mythread(Runnable r){
super(r);
}
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("MyThread run");
for(int i = 0;i < 100;i ++){
System.out.println(Thread.currentThread().getName()+" = "+i);
}
}
}
class MyRunnable implements Runnable{
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("MyRunnable run");
for(int i = 0;i < 100;i ++){
System.out.println(Thread.currentThread().getName()+" = "+i);
}
}
}

最后执行的是MyThread里面的run方法。这是为什么呢?
当我们去查看源码,Runnable只有一个run方法,Thread实现Runnable接口,在Thread里面对于run方法的定义

@Override
public void run() {
if (target != null) {
target.run();
}
}

也就是当Thread执行到run方法时,在Thread类定义了

 /* What will be run. */
private Runnable target;

会判断是否有target存在,如果有,则执行Runnable里面的run方法,但是有多态的存在,会直接执行子类MyThread的run方法,于是不会再去调用MyRunnable的run方法了,也就是不会去调用MyRunnable的run方法。

智能推荐

注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
© 2014-2019 ITdaan.com 粤ICP备14056181号  

赞助商广告