文章目录

this是当前代码所处的对象的线程,Thread.currentThread()是运行当前代码的线程。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31

public class CountOperate extends Thread{
public CountOperate() {
System.out.println("CountOperate.CountOperate()");
System.out.println("Thread-currentThread.getName()"+Thread.currentThread().getName());
System.out.println("Thread-currentThread.isAlive()"+Thread.currentThread().isAlive());
System.out.println("this.getName()"+this.getName());
System.out.println("this.isAlive()"+this.isAlive());
System.out.println("Thread-currentThread==this"+(Thread.currentThread()==this));
System.out.println("CountOperate.CountOperate()");
}
@Override
public void run() {
System.out.println("CountOperate.run()"+Thread.currentThread().getName());
System.out.println("Thread-currentThread.getName()"+Thread.currentThread().getName());
System.out.println("Thread-currentThread.isAlive()"+Thread.currentThread().isAlive());
System.out.println("this.getName()"+this.getName());
System.out.println("this.isAlive()"+this.isAlive());
System.out.println("Thread-currentThread==this"+(Thread.currentThread()==this));
System.out.println("CountOperate.run()");
}
public static void main(String[] args) {
CountOperate c=new CountOperate();
c.start();
Thread t1=new Thread(c);
System.out.println("main t1.isAlive()"+t1.isAlive());
t1.setName("t1");
t1.start();
System.out.println("main t1.isAlive()"+t1.isAlive());
}
}

打印的log

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
//-----------------------------------------------
CountOperate.CountOperate() //new CountOperate()的构造函数
Thread-currentThread.getName()main //jvm创建一个进程,默认有一个线程调用main
Thread-currentThread.isAlive()true
this.getName()Thread-0 //当前new的CountOperate()对象的线程
this.isAlive()false
Thread-currentThread==thisfalse
CountOperate.CountOperate()
//------------------------------------------------
main t1.isAlive()false //t1没有调用start()方法
main t1.isAlive()true //t1调用过start()方法
//------------------------------------------------
CountOperate.run()Thread-0 //c.start()调用run()
Thread-currentThread.getName()Thread-0
Thread-currentThread.isAlive()true
this.getName()Thread-0 //this当前线程
this.isAlive()true
Thread-currentThread==thistrue
CountOperate.run()
//------------------------------------------------
CountOperate.run()t1
Thread-currentThread.getName()t1 //Thread t1=new Thread(参数),
Thread-currentThread.isAlive()true //t1是new的Thread,与传递的参数无关
this.getName()Thread-0 //传过来的c对象参数,当执行t1.start(),
this.isAlive()false //会调用c的run()方法
Thread-currentThread==thisfalse
CountOperate.run()

根据打印的Log可以知道调用CountOperate构造函数的是main线程,因此打印出

Thread.currentThread().getName()=main
Thread.currentThread().isAlive()=true
而此时还没有启动CountOperate子线程所以打印出
this.getName=Thread-0
this.isAlive()=false

此时this代表的是CountOperate对象实例,所以
Thread.currentThread()==this :false

这里比较让人疑惑的是“this.getName() = Thread-0”,这个Thread-0是什么东西???
通过查看Thread源码发现,在Thread类的构造方法中,会自动给name赋值,赋值代码:

1
2
3
public Thread() {
init(null, null, "Thread-" + nextThreadNum(), 0);
}

然后执行到:
Thread t1 = new Thread(c);
System.out.println(“main begin t1 isAlive=” + t1.isAlive());
t1.setName(“t1”);
t1.start();

打印:
Thread-currentThread.getName()t1
Thread-currentThread.isAlive()true
Thread.currentThread()==this :false
this.getName()=Thread-0
this.isAlive()=false
说明此时的this和Thread.currentThread()指向不是同一个线程实例

也就是说,this指向的还是new CountOperate()创建的那个线程实例,而不是new Thread(thread)创建的那个实例即t1。
查看源代码可以知道

1
2
3
public Thread(Runnable target) {
init(null, target, "Thread-" + nextThreadNum(), 0);
}

实际上new Thread(thread)会将thread应用的对象绑定到一个pravite变量target上,
在t1被执行的时候即t1.run()被调用的时候,它会调用target.run()方法,也就是说它是直接调用thread对象的run方法,
再确切的说,在run方法被执行的时候,this.getName()实际上返回的是target.getName(),而Thread.currentThread().getName()实际上是t1.getName()。

文章目录