如下的code:
public class Thread_getName2 extends Thread {
public void run() {
//System.out.println(getName());
System.out.println(currentThread().getName());
}
public static void main(String[] args) {
Thread_getName2 t = new Thread_getName2();
t.start();
t.run();
}
}
如果调用this.getName(),打印结果如下:
t.start(); // Thread-0
t.run(); // Thread-0
调用currentThread().getName(),打印结果如下:
t.start(); // Thread-0
t.run(); // main
以上哪种结果才是正确的呢?
应该是第二种currentThread().getName()
首先可以理解t.run()方法应该是由主线程调用的,而直接调用getName()时却打印出了Thread-0,这是不正确的。
那为什么getName()会产生这样的结果呢?
首先Thread_getName2 t = new Thread_getName2();
这个时候如果打印下t,会发现t的值为: Thread[Thread-0,5,main],这个可以看Thread类的toString()方法,
ThreadGroup group = getThreadGroup();
// java.lang.ThreadGroup[name=main,maxpri=10]
if (group != null) {
return "Thread[" + getName() + "," + getPriority() + "," +
group.getName() + "]";
}
而以下两种方式是一样的
System.out.println(getName());
System.out.println(this.getName());
而this就是当前的t,所以t.run()也会打印出Thread-0。
通过以上的比较,如果要得到准确的线程的名称,必须要先调用currentThread()得到当前是哪个线程,而后调用getName()才能得出正确的结果。
如果单单只是调用getName()则会产生错误的结果。