首先是这段代码:
package ss;
class CountOperate extends Thread{
public CountOperate(){
System.out.println("构造函数开始");
System.out.println("Thread.currentThread.getName="+Thread.currentThread().getName());
System.out.println("this.getName="+this.getName());
System.out.println("构造函数end");
}
@Override
public void run() {
// TODO Auto-generated method stub
super.run();
System.out.println("run函数开始");
System.out.println("Thread.currentThread.getName="+Thread.currentThread().getName());
System.out.println("this.getName="+this.getName());
System.out.println("run函数end");
}
}
public class Main {
public static void main(String[] args) {
CountOperate c =new CountOperate();
Thread t1=new Thread(c);
t1.setName("A");
t1.start();
}
}
打印结果:
构造函数开始
Thread.currentThread.getName=main
this.getName=Thread-0
构造函数end
run函数开始
Thread.currentThread.getName=A
this.getName=Thread-0
run函数end
一直很好奇为什么出现的结果不是两个Main两个A,百度了一下,说是因为代码中CountOperate c =new CountOperate();的原因。
首先,Thread.currentThread和this指向的应该是同一个线程实例,那么调用getName()后的线程实例名字应该相同。可是结果中的this和Thread.currentThreat()指向的不是同一个线程实例。也就是说,this指向的还是new CountOperate ()创建的那个线程实例,而不是new Thread(c)创建的那个实例即t1。查看源代码可以知道。实际上new Thread(c)会将c应用的对象绑定到一个pravite变量target上,在t1被执行的时候即t1.run()被调用的时候,它会调用target.run()方法,也就是说它是直接调用thread对象的run方法,再靠近点说,在run方法被执行的时候,this.getName()实际上返回的是target.getName(),而Thread.currentThread().getName()实际上是t1.getName()。