本文参考https://www.cnblogs.com/dolphin0520/p/3913517.html 并做了一点修改,新建了一个线程。
文中根据输出结果可以得出以下结论:
1)thread1和thread2的线程ID不同,thread2和主线程ID相同,说明通过run方法调用并不会创建新的线程,而是在主线程中直接运行run方法,跟普通的方法调用没有任何区别;
2)虽然thread1的start方法调用在thread2的run方法前面调用,但是先输出的是thread2的run方法调用的相关信息,说明新线程创建的过程不会阻塞主线程的后续执行。
一、结论
1. 调用start方法,就会创建一个新的线程,这时线程处于就绪(可运行)状态,但并没有运行,一旦得到CPU时间片,就开始运行,并执行run方法。
2. run方法只是定义需要并行执行的任务,如果直接调用run方法,即相当于在主线程中执行run方法,跟普通的方法调用没有任何区别,并不会创建一个新的线程来执行定义的任务,程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才能才可继续执行下面的代码。
通过打印结果可以看出新建的线程和主线程是各自执行、互不影响的,即参考文章中说的不会阻塞的意思。
二、代码
public class Test {
public static void main(String[] args) {
System.out.println("主线程ID:"+Thread.currentThread().getId());
MyThread thread1 = new MyThread("thread1");
thread1.start();
MyThread thread2 = new MyThread("thread2");
thread2.start();
thread2.run();
}
}
class MyThread extends Thread{
private String name;
public MyThread(String name){
this.name = name;
}
@Override
public void run() {
System.out.println("name:"+name+" 子线程ID:"+Thread.currentThread().getId());
}
}
打印结果(不唯一):