线程中Thread.currentThread()和this的区别

线程中有两个对象在刚开始的时候会遇到:

Thread.currentThread().getName();

this.getName()

能够this.getName()的前提是你必须继承了Thread类, .getName()方法是从Thread类中继承下来的;

现在看代码:

public class MyThread  extends Thread{

	@Override
	public void run() {
		// TODO Auto-generated method stub
		System.out.println(Thread.currentThread().getName());
		System.out.println(this.getName());
	}
	
}

main方法:

public class MyRun {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		MyThread t1=new MyThread();
		t1.run();
		t1.start();
	}

}

运行结果:

main
Thread-0
Thread-0
Thread-0

首先第一个结果"main",是运行了下面这个代码

System.out.println(Thread.currentThread().getName());

Thread.currentThread()获取的是当前执行的线程,而因为没有开始线程只是调用了类中的run方法,所以还只是main这个线程在执行.

第二个结果"Thread-0",是运行了下面这个代码:

System.out.println(this.getName());

this.getName()调用的是当前对象的方法,而当前对象我并没有写该方法,那就是调用它父类Thread的方法,而且我们在初始化的时候也并没有命名,那这"Thread-0"又是从何而来呢,进入Thread类查看:

首先找到name属性:

可以看到该name是没有被初始化的;

那么找到该Thread类的接口Runnable初始化构造函数:

在这里我们还是看不出来name是如何赋值的,进入"init()"方法继续查看:

从这里我们就看到了"name"值被传入一个"Thread-",但是后面的"0"我找了很久是真的没找到,但是这并不影响我们的推断,那就是this指的是本对象,而Thread.current指向的是当前线程.

第三个结果和第三个结果还不好解释,修改代码:

增加一行代码:

运行结果:

也就是说,在线程未开启的时候,两个对象不是同一个,this对象是本身对象,而Thread.currentThread()是main对象;

当线程启动的时候,Thread.currentThread()对象就是this对象了;

所以说到底应该能够动后面两个结果是为什么了.

猜你喜欢

转载自blog.csdn.net/qq_37909508/article/details/89094777