一、join方法
执行该方法的线程进入阻塞状态,直到调用该方法的线程结束后再由阻塞转为就绪状态
1.例一
import java.util.Date;
class TimeThread extends Thread{
@Override
public void run() {//计数器线程进入阻塞状态后,时间线程获得了CPU的使用权,进入运行状态
for(int i=0;i<=2; i++){
System.out.println("时间线程:"+new Date());//等时间线程结束以后,计数器线程才重新进入就绪状态,获得CPU的使用权,进入运行状态
try {
sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class CounterThread extends Thread {
private TimeThread timeThread;
public CounterThread(TimeThread timeThread){
this.timeThread = timeThread;
}
//计数器线程抢占到CPU的资源,优先进入运行状态
@Override
public void run() {
for(int i=1;i<=3; i++){
if(i==2){
try {
//执行join方法的线程进入阻塞状态,调用join方法的线程进入就绪状态
timeThread.join();//计数器线程进入阻塞状态,时间线程进入就绪状态
} catch (InterruptedException e) {
System.out.println("计数器线程提前结束阻塞状态");
}
}
System.out.println("计数器线程:"+i);//先抢占到CPU输出计数器线程:1
}
}
}
public class Program {
public static void main(String[] args) {//主线程
TimeThread timeThread = new TimeThread();//创建timeThread线程
timeThread.start();//timeThread线程就绪
CounterThread counterThread = new CounterThread(timeThread);//创建counterThread线程
counterThread.start();//counterThread线程就绪
}
}
执行结果
①该代码执行结果为计数器线程先获得CPU的使用权
②假如时间线程先获得CPU的使用权
③则时间线程输出一次时间后,时间线程进入阻塞状态
④这时计数器线程获得CPU的使用权,从就绪状态变为运行状态
⑤计数器线程输出一次后,i=2进入if语句
⑥时间线程调用join方法,计数器线程阻塞
⑦时间线程进入就绪状态获得CPU的使用权进入运行状态
⑧等到时间线程运行结束
⑨计数器线程重新获得CPU的使用权结束阻塞状态运行输出
2.例二
只有处于就绪状态的线程才能调用join方法
import java.util.Date;
class TimeThread extends Thread{
@Override
public void run() {
for(int i=0;i<=2; i++){
System.out.println("时间线程:"+new Date());
try {
sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class CounterThread extends Thread {
//计数器线程抢占到CPU的资源,优先进入运行状态
@Override
public void run() {
for(int i=1;i<=3; i++){
if(i==2){
try {
new TimeThread().join();
} catch (InterruptedException e) {
e.printStackTrace();
}//由于时间线程只处于新建状态,没有调用start方法处于就绪状态,故调用了join方法也没有效果
}
System.out.println("计数器线程:"+i);//先抢占到CPU输出计数器线程:1
}
}
}
public class Program {
public static void main(String[] args) {//主线程
CounterThread counterThread = new CounterThread();//创建counterThread线程
counterThread.start();//counterThread线程就绪
}
}
执行结果