Java的线程的join()方法

Java的线程的join()方法

Java的线程的join()方法是让当前的线程进入Blocked/Waiting状态,让调用该join()的Thread对象执行完毕后,才让当前线程进入Runnable状态,它有三个重载的方法:

public final void join()

该方法就是上文提到的,让当前线程进入Blocked/Waiting状态,让调用join()的Thread对象进入Dead状态之后,当前线程才能进入Runnable状态。

public final synchronized void join(long millis)

该方法让当前线程等待调用join(long t)的Thread对象t毫秒之后,或者等待该Thread对象进入Dead状态后,该线程重新进入Runnable状态,由于线程的执行依赖于OS的实现方法,我们并不能保证让当前线程等待我们所指定的时间。

public final synchronized void join(long millis, int nanos)

与上述方法一致,只不过加入纳秒而已。

package Test;

/**
 * Created by siege on 2015-09-13.
 */
public class ThreadJoinExample{
    public static void main(String[] args) {
        Thread t1 = new Thread(new MyRunnable(), "t1");
        Thread t2 = new Thread(new MyRunnable(), "t2");
        Thread t3 = new Thread(new MyRunnable(), "t3");

        t1.start();

        //等t1执行完毕或者2秒后,再开始t2线程。
        try {
            t1.join(2000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        t2.start();

        //t1线程执行完毕后再开始t3线程
        try {
            t1.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        t3.start();

        //让t1,t2,t3执行完毕之后,再执行main线程
        try {
            t1.join();
            t2.join();
            t3.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("All threads are dead, exiting main thread");
    }

}

class MyRunnable implements Runnable{

    @Override
    public void run() {
        System.out.println("Thread started:::"+Thread.currentThread().getName());
        try {
            Thread.sleep(4000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("Thread ended:::"+Thread.currentThread().getName());
    }

}

执行结果:

Thread started:::t1
Thread started:::t2
Thread ended:::t1
Thread started:::t3
Thread ended:::t2
Thread ended:::t3
All threads are dead, exiting main thread

猜你喜欢

转载自blog.csdn.net/u010999240/article/details/48423743