`
加菲学Java
  • 浏览: 132573 次
  • 性别: Icon_minigender_1
  • 来自: 扬州
社区版块
存档分类
最新评论

Thread : currentThread().getName()和getName()的区别

 
阅读更多

如下的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()则会产生错误的结果。






 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics