Java并发编程中Thread.join使用方法

Thread.join()用于线程同步,使当前线程等待目标线程执行完毕后再继续执行,确保任务顺序完成。

在Java并发编程中,Thread.join() 是一个用于线程同步的重要方法。它的主要作用是让当前线程等待调用join()的线程执行完毕后再继续执行。这种机制在需要确保某个线程完成后再进行后续操作时非常有用。

1. 基本用法:无参join()

调用 thread.join() 后,当前线程会一直阻塞,直到目标线程运行结束。

例如:

Thread thread = new Thread(() -> {
    for (int i = 0; i < 5; i++) {
        System.out.println("子线程运行: " + i);
        try {
            Thread.sleep(500);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
});
thread.start();
try {
    thread.join(); // 主线程等待子线程完成
} catch (InterruptedException e) {
    e.printStackTrace();
}
System.out.println("子线程已结束,主线程继续");

输出结果会保证“子线程已结束”一定在子线程打印完所有内容后才出现。

2. 带超时时间的join(long millis)

使用 join(long millis) 可以设置最大等待时间,避免无限等待。

如果指定时间内目标线程未结束,当前线程将不再等待,继续执行后续代码。

示例:

thread.start();
try {
    thread.join(2000); // 最多等待2秒
} catch (InterruptedException e) {
    e.printStackTrace();
}
System.out.println("等待结束(可能子线程还没完成)");

这个方法适用于对响应时间有要求的场景,防止程序卡死。

3. join(long millis, int nanos)

该版本允许更精确地指定等待时间,包括纳秒级别。但实际精度受系统定时器和JVM实现限制,一般不常用。

语法:

thread.join(1000, 500000); // 等待1秒又500000纳秒

4. 注意事项与常见问题

使用join()时需要注意以下几点:

  • 必须捕获 InterruptedException,因为等待过程可能被中断
  • 如果在目标线程已经结束后调用join(),会立即返回
  • 不能在目标线程自身内部调用join(),否则会导致死锁
  • 多个线程都可以对同一个线程调用join()

基本上就这些。合理使用Thread.join()能有效控制线程执行顺序,简化并发逻辑处理。虽然功能简单,但在串行化线程执行流程时非常实用。