线程等待
线程之间是并发执行的关系,多个线程之间,谁先执行,谁后执行,谁执行到哪里让出CPU…作为程序员是完全无法感知的,全权由操作系统内核负责。例如:创建一个新线程的时候,此时接下来是主线程继续执行,还是新线程继续执行,这个事情是不好保证的。
虽然咱们没法控制哪个线程先开始,哪个线程后开始,但是可以控制让哪个线程先结束,哪个线程后结束。(借助于线程等待)。
join方法
join方法:执行join方法的线程就会阻塞,一直阻塞到对应线程执行结束之后,才会继续执行往下执行,它存在的意义就是为了控制线程结束的先后顺序。{
多线程的一个场景:例如要进行一个复杂的计算,主线程把任务分成几份,每个线程计算自己一份的任务,当所有任务都被分别计算完毕之后,主线程再来汇总。(就是要保证主线程是最后执行完的线程)
}
如果线程已经结束了,才调用到join,此时join也会立刻返回,没有影响。
线程等待代码示例
package Java0510;
/**
* @author wgsstart
* @creat 2021-05-10 18:11
*/
public class ThreadDemo12 {
public static void main(String[] args) throws InterruptedException {
Thread t1 = new Thread() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("我是线程1");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
};
Thread t2 = new Thread() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("我是线程2");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
};
t1.start();
t1.join();
t2.start();
t2.join();
}
}