java多线程01:创建线程的两种传统方式

Thread类内部有个run()方法,线程执行时就是执行这个方法,源码为:

private Runnable target;
    public void run() {
        if (target != null) {
            target.run();
        }
    }


其中target是一个Runnable接口对象,可以看到线程在执行时其实是在执行target的run()方法。

创建线程的第一种方式:继承Thread类,即使用Thread的子类,并重写run()方法

       //1 使用Thread的子类
Thread thread1 = new Thread()
{
@Override
public void run() 
{
while(true)
{
System.out.println("thread1: " + Thread.currentThread().getName());
}
}
};
这里的run()方法不是target的run()方法,是子类重写的run()方法


创建线程的第二种方式:传递Runnable接口对象构造
//2 传入Runnable对象
Thread thread2 = new Thread(new Runnable(){
@Override
public void run() 
{
while(true)
{
System.out.println("thread2: " + Thread.currentThread().getName());
}
}
});
这里没有使用子类继承的方式,调用的是Thread类的run()方法,从源码可以看到,该run()方法内部调用的是target的run()方法,就是这里实现的run()方法

来看一件有意思的事情:

//3 运行谁的run方法?
Thread thread3 = new Thread(new Runnable(){
@Override
public void run() 
{
while(true)
{
System.out.println("Runnable对象的run方法: " + Thread.currentThread().getName());
}
}
}){
@Override
public void run() 
{
while(true)
{
System.out.println("子类thread3的run方法: " + Thread.currentThread().getName());
}
}
};
这里构造了Thread子类对象thread3,并且在构造函数中传入了一个Runnable接口对象给thread3的target成员变量,由于子类重写了run()方法,所以thread3在执行时会调用重写的run()方法(第二个run()方法),如果这里的子类没有重写run()方法,很显然会去调用父类即Thread类的run()方法,该方法内部再去调用target的run()方法,即这里构造函数里实现的run()方法(第一个run()方法)。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章