答案:Java中控制线程执行顺序常用join()、synchronized与wait/notify、CountDownLatch和Semaphore。通过join()可实现线程间先后依赖,如A.join()确保A执行完再执行B;利用synchronized配合wait/notify可根据共享状态精确控制多线程交替执行;CountDownLatch适用于等待多个前置任务完成后再继续,如C等待A和B均调用countDown()后开始;Semaphore通过信号量许可实现顺序传递,如首个线程执行后释放下一许可。选择方法需根据场景:简单顺序用join,复杂协调用wait/notify或Semaphore,批量等待用CountDownLatch,关键在于理解机制并避免死锁。

在Java中控制线程执行顺序,核心是通过线程间的同步机制来实现。虽然线程默认是并发无序执行的,但可以通过一些手段让多个线程按指定顺序协作运行。以下是几种常用且实用的方法。
使用 join() 方法
一个线程调用另一个线程的 join() 方法时,当前线程会阻塞,直到目标线程执行完成。这种方式适合明确的前后依赖关系。
例如,希望线程 B 在线程 A 执行完后再运行:- 启动线程 A
- 在主线程或后续逻辑中调用 A.join()
- 再启动线程 B
这样就能保证 A 先于 B 执行完毕。
使用 synchronized 和 wait/notify
通过对象锁配合 wait() 和 notify() 可以精确控制线程执行顺序。适用于多个线程之间需要交替执行的场景。
立即学习“Java免费学习笔记(深入)”;
比如三个线程按 A → B → C 的顺序循环执行:- 定义一个共享状态变量表示当前应执行的线程
- 每个线程进入 synchronized 块后检查状态
- 不符合条件则调用 wait() 等待
- 执行完成后更新状态并 notify() 唤醒其他线程
注意必须在 synchronized 块中调用 wait/notify,否则会抛出异常。
使用 CountDownLatch
CountDownLatch 是一个倒计时门闩,适合等待某些前置任务完成后再继续的场景。
例如线程 C 必须等线程 A 和 B 都完成后才开始:- 创建 CountDownLatch(2)
- A 和 B 执行完各自任务后调用 countDown()
- C 在开始前调用 await(),直到计数归零才会继续
这种方式不强调线程之间的严格顺序,而是等待一组操作完成。
使用 Semaphore(信号量)
Semaphore 可以控制同时访问资源的线程数量,也能用于顺序协调。
比如让线程按固定顺序执行:- 初始化多个 Semaphore,初始许可为 0
- 第一个线程无需等待,执行后释放第二个线程的许可
- 第二个线程 acquire() 后执行,再释放第三个的许可
通过传递“通行证”的方式实现顺序控制,逻辑清晰且易于扩展。
基本上就这些常见方式。选择哪种取决于具体需求:简单依赖用 join,精细控制用 wait/notify 或 Semaphore,等待多任务完成用 CountDownLatch。关键是理解每种工具的语义,避免死锁和竞态条件。










