Java多线程join()

thread.Join把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程A的Join()方法,直到线程A执行完毕后,才会继续执行线程B。
也可以在调用join()时带上一个超时的参数,这样如果目标线程A在这段时间到期时还没有结束的话,join()方法返回,执行线程B,这个时候AB两个线程一起执行。 并且对join()方法的调用可以被中断,做法是在调用线程上调用interrupt()方法。

public class Sleeper extends Thread {

    private int duration;
    public Sleeper(String name,int sleepTime){
        super(name);
        duration = sleepTime;
        start();
    }

    @Override
    public void run() {
        try {
            sleep(duration);
        } catch (Exception e) {
            System.out.println(getName() + "被中断。" + "isInterrupted():" + isInterrupted());
        }

        System.out.println(getName() + "已唤醒。");
    }

}

这里写图片描述

public class Joiner extends Thread {

    private Sleeper sleeper;
    public Joiner(String name,Sleeper sleeper){
        super(name);
        this.sleeper = sleeper;
        start();
    }

    @Override
    public void run() {
        try {
            sleeper.join();

        } catch (Exception e) {
            // TODO: handle exception
        }

        System.out.println(getName() + "加入完成。");
    }

    public static void main(String[] args) {
        Sleeper sleepy = new Sleeper("Sleepy", 1500),
                grumpy = new Sleeper("Grumpy", 1500);

        Joiner dopey = new Joiner("Dopey", sleepy),
               doc = new Joiner("Doc", grumpy);
        sleepy.interrupt();
    }
}

这里写图片描述

join()使用意义:

主线程B生成并起动了子线程A,而子线程A里要进行大量的耗时的运算,当主线程B处理完其他的事务后,需要用到子线程A的处理结果,这个时候就要用到join()方法了。

Java中,可以使用`join()`方法来实现多线程的等待和同步操作。 `join()`方法是`Thread`类中的一个方法,它允许一个线程等待另一个线程完成其执行。当在一个线程上调用`join()`方法时,调用线程将被阻塞,直到被调用的线程完成。这意味着,如果一个线程A调用了线程B的`join()`方法,那么线程A将等待线程B执行完毕后再继续执行。 下面是一个简单的示例,演示了`join()`的使用: ```java public class JoinExample { public static void main(String[] args) throws InterruptedException { Thread thread1 = new Thread(new Runnable() { @Override public void run() { System.out.println("Thread 1 started"); try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Thread 1 finished"); } }); Thread thread2 = new Thread(new Runnable() { @Override public void run() { System.out.println("Thread 2 started"); try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Thread 2 finished"); } }); thread1.start(); thread2.start(); // 等待thread1和thread2执行完毕 thread1.join(); thread2.join(); System.out.println("All threads finished"); } } ``` 在上面的例子中,我们创建了两个线程`thread1`和`thread2`,分别输出一些信息并休眠一段时间。在主线程中,我们调用了`thread1.join()`和`thread2.join()`,这将使主线程等待`thread1`和`thread2`执行完毕。最后,当所有线程执行完毕后,主线程输出"All threads finished"。 通过使用`join()`方法,我们可以实现多线程的等待和同步操作,确保在需要的时候线程之间的执行顺序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值