jdk7对此一句话:Waits for this thread to die(等待这个线程死亡)其它的线程的状况如何就不太清楚了。 多线程
仍是本身动手笔划两下:用三个线程来测试t1,t2,main 测试
1、Thread t1 = new Thread(){
public void run(){
int i = 0;
while(i++ < 10){
try {
Thread.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("t1:" + i);
}
}
};
Thread t2 = new Thread(){
public void run(){
int i = 0;
while(i++ < 100){
try {
Thread.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("t2:" + i);
}
}
};
t1.start();
try {
t1.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
t2.start();
for(int i = 0;i < 1000; i++){
System.out.println("main:" + i);
try {
Thread.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} this
这个程序结果是 t1先执行完(t1 is died),而后t2 和 main交叉输出结果。 线程
2、将t1.join()放到t2.start()后面 it
t1.start();
t2.start(); io
try {
t1.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} thread
(其它的同上) jdk
先是t1和t2交叉执行,t1执行完后(t1 is died),剩下的t2还没执行的部分和main交叉执行。 程序
3、 将t1.join()放到最后面,则三个线程跟普通多线程没什么区别,谁先执行完谁先死。。。 方法
总之,根据我运行出的结果看join()是阻塞在它后面的线程 ,只要在这个以前的则不受影响,包括主线程。
因此第一句话完整的说法是:等待调用这个方法(join()方法)的线程死亡后,此方法后面的线程才能执行,前面的线程不受影响。
(若有不对或不实的地方,请多多批评和指正)