如何保证线程的执行顺序

本文探讨了在Java中如何确保线程按照特定顺序执行,提供了两种有效的方法:使用Thread类的join()方法和利用只有一个线程的线程池。通过实例代码详细解释了这两种方案的实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如题,如何保证线程的执行顺序?

1
2
Thread1
Thread2
Thread3
方案一
public class ThreadOrder {

    static Thread thread1 = new Thread(new Runnable() {
        @Override
        public void run() {
            System.out.println("thread1");
        }
    });

    static Thread thread2 = new Thread(new Runnable() {
        @Override
        public void run() {
            System.out.println("thread2");
        }
    });

    static Thread thread3 = new Thread(new Runnable() {
        @Override
        public void run() {
            System.out.println("thread3");
        }
    });

    public static void main(String[] args) throws InterruptedException {
        thread1.start();
        // join()方法,让主线程阻塞
        thread1.join();
        thread2.start();
        thread2.join();
        thread3.start();
        thread3.join();
    }
}
java.lang.Thread#join(long)的实现
public final void join() throws InterruptedException {
        join(0); // 这里时间设置为0毫秒
    }
public final synchronized void join(long millis)
    throws InterruptedException {
        long base = System.currentTimeMillis();
        long now = 0;

        if (millis < 0) {
            throw new IllegalArgumentException("timeout value is negative");
        }

        if (millis == 0) {
            while (isAlive()) {
                wait(0);
            }
        } else {
            while (isAlive()) {
                long delay = millis - now;
                if (delay <= 0) {
                    break;
                }
                wait(delay);
                now = System.currentTimeMillis() - base;
            }
        }
    }
方案二
public class ThreadOrder {
     ...
     // 利用只有一个线程的线程池,按顺序执行thread1 -> thread2 -> thread3
    static ExecutorService executorService = Executors.newSingleThreadExecutor();
    public static void main(String[] args) throws InterruptedException {
        executorService.submit(thread1); // 1、执行thread1
        executorService.submit(thread2); // 2、执行thread2
        executorService.submit(thread3); // 3、执行thread3
        executorService.shutdown();
    }
}
执行结果:
在这里插入图片描述
勘误或支持:由于水平有限,编写时间仓促,文中难免会出现一些错误或者不准确的地方,恳请读者批评指正。有任何的意见或建议,可在评论区留言,共同讨论。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值