java Thread join方法
2016-09-11 15:07
295 查看
Thread.join()是指的是让主线程等待子线程运行结束之后继续执行。我们先来看一看不适用join的情况。
public class Test{
public static void main(String[] args0){
Thread1 thread1 = new Thread1();
thread1.start();
}
static class Thread1 extends Thread{
public void run(){
System.out.println("我是线程1,我开始执行");
try {
sleep(3000);
System.out.println("我将调用线程2的join方法");
Thread2 thread2 = new Thread2();
thread2.start();
//thread2.join();
System.out.println("线程1结束");
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
static class Thread2 extends Thread{
public void run(){
System.out.println("我是线程2");
try {
sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}从上面可以看到我们使用创建了两个Thread类,分别是thread1和thread2,在main函数中实例化thread1,在thread1的run方法中实例化Thread2,并调用start方法来把thread2变为runnable状态,我们运行之后发现结果如下:
我是线程1,我开始执行
我将调用线程2的join方法
线程1结束
我是线程2
发现thread2虽然在thread1中变为了runnable状态,但是并没有获得cpu时间。任然是等到thread1运行结束之后才开run。
现在我们将上面的注释去掉:
public class Test{
public static void main(String[] args0){
Thread1 thread1 = new Thread1();
thread1.start();
}
static class Thread1 extends Thread{
public void run(){
System.out.println("我是线程1,我开始执行");
try {
sleep(3000);
System.out.println("我将调用线程2的join方法");
Thread2 thread2 = new Thread2();
thread2.start();
thread2.join();
System.out.println("线程1结束");
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
static class Thread2 extends Thread{
public void run(){
System.out.println("我是线程2");
try {
sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}结果就是thread1在调用thread2.join之后就进入了阻塞状态,而thread2转为运行状态。
public class Test{
public static void main(String[] args0){
Thread1 thread1 = new Thread1();
thread1.start();
}
static class Thread1 extends Thread{
public void run(){
System.out.println("我是线程1,我开始执行");
try {
sleep(3000);
System.out.println("我将调用线程2的join方法");
Thread2 thread2 = new Thread2();
thread2.start();
//thread2.join();
System.out.println("线程1结束");
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
static class Thread2 extends Thread{
public void run(){
System.out.println("我是线程2");
try {
sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}从上面可以看到我们使用创建了两个Thread类,分别是thread1和thread2,在main函数中实例化thread1,在thread1的run方法中实例化Thread2,并调用start方法来把thread2变为runnable状态,我们运行之后发现结果如下:
我是线程1,我开始执行
我将调用线程2的join方法
线程1结束
我是线程2
发现thread2虽然在thread1中变为了runnable状态,但是并没有获得cpu时间。任然是等到thread1运行结束之后才开run。
现在我们将上面的注释去掉:
public class Test{
public static void main(String[] args0){
Thread1 thread1 = new Thread1();
thread1.start();
}
static class Thread1 extends Thread{
public void run(){
System.out.println("我是线程1,我开始执行");
try {
sleep(3000);
System.out.println("我将调用线程2的join方法");
Thread2 thread2 = new Thread2();
thread2.start();
thread2.join();
System.out.println("线程1结束");
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
static class Thread2 extends Thread{
public void run(){
System.out.println("我是线程2");
try {
sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}结果就是thread1在调用thread2.join之后就进入了阻塞状态,而thread2转为运行状态。
我是线程1,我开始执行 我将调用线程2的join方法 我是线程2 线程1结束
相关文章推荐
- Java多线程学习 (二) Thread的join()方法
- Java Thread Join方法
- java谜题--Thread.join()方法容易忽略的地方
- java中Thread类的join()方法
- Java中的线程Thread方法之---join()
- Java基础 thread的join方法
- java中Thread类的join()方法
- Java之Thread的join方法实例
- Java中的线程Thread方法之---join()
- java中synchronize锁 volatile thread.join()方法的使用
- java Thread的join()方法
- 浅析Java的Thread.join()方法
- JAVA THREAD.JOIN方法详解
- Java Thread.join()方法
- Java Thread.join()方法
- Java 多线程CountDownLatch、CyclicBarrier、Thread.join方法基本用法
- java--java.lang.Thread.join() 方法
- Java中的线程Thread方法之---join()
- Java多线程(一)——Thread之join()方法
- Java的Thread的start(),run()和join()方法