Thread 的join方法
package com.cn.test.thread; public class TestJoin extends Thread{ private String name; public TestJoin(String name) { this.name = name; } public static void main(String[] args) { TestJoin join1 = new TestJoin("thread-1"); TestJoin join2 = new TestJoin("thread-2"); join1.start(); join2.start(); try { join1.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("main--------------------线程"); } @Override public void run() { for (int i=0; i<3; i++) { System.out.println(Thread.currentThread().getName() + "i=" + i) ; } } }
上述例子中: 在main方法中join1线程调用join方法,如果main方法抢到cpu的执行权,会将cpu的执行权让出来给join1线程,直到join1线程执行完毕之后才进行main线程的执行。join1和join2是同步进行竞争cpu的资源。
运行结果:
Thread-0i=0 Thread-1i=0 Thread-0i=1 Thread-1i=1 Thread-0i=2 Thread-1i=2 main--------------------线程
main线程需要等待join1线程执行完毕之后才能进行执行
Thread的join方法在start方法之前进行执行,不会触发这种cpu让出执行权的操作,此时和mian线程是并发执行的。
package com.cn.test.thread;
public class TestJoin extends Thread{
private String name;
public TestJoin(String name) {
this.name = name;
}
public static void main(String[] args) {
TestJoin join1 = new TestJoin("thread-1");
TestJoin join2 = new TestJoin("thread-2");
try {
join1.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
join1.start();
join2.start();
System.out.println("main--------------------线程");
}
@Override
public void run() {
for (int i=0; i<3; i++) {
System.out.println(Thread.currentThread().getName() + "i=" + i) ;
}
}
}
执行结果:
main--------------------线程 Thread-1i=0 Thread-1i=1 Thread-1i=2 Thread-0i=0 Thread-0i=1 Thread-0i=2
总结:join方法可以控制多线程的执行顺序。

浙公网安备 33010602011771号