码迷,mamicode.com
首页 > 编程语言 > 详细

如何保证线程的执行顺序

时间:2018-05-25 21:28:33      阅读:240      评论:0      收藏:0      [点我收藏+]

标签:sys   str   优先级   thread   []   AC   tor   illegal   mem   

示例代码

static Thread t1 = new Thread(new Runnable() {
public void run() {
System.out.println("Thread1");
}
});
static Thread t2 = new Thread(new Runnable() {
public void run() {
System.out.println("Thread2");
}
});
static Thread t3 = new Thread(new Runnable() {
public void run() {
System.out.println("Thread3");
}
});
1.使用join
public static void main(String[] args) throws InterruptedException {
t1.start();
t1.join();
t2.start();
t2.join();
t3.start();
}
join源码:
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;
            }
        }
    }
join让主线程等待,至子线程执行结束
2.使用ExecutorService
static ExecutorService es = Executors.newSingleThreadExecutor();
public static void main(String[] args) throws InterruptedException {
es.submit(t1);
es.submit(t2);
es.submit(t3);
es.shutdown();
}
ExecutorService 提供了4种线程池,分别是:
newCachedThreadPool;缓存线程池,可灵活回收、新建
newFixedThreadPool;定长线程池,可控制最大并发数,超出在队列中等待
newScheduledThreadPool;定长线程池,可定时、周期执行
newSingleThreadExecutor;单一线程池,按顺序执行(FIFO,LIFO,优先级)

如何保证线程的执行顺序

标签:sys   str   优先级   thread   []   AC   tor   illegal   mem   

原文地址:https://www.cnblogs.com/csong7876/p/9090346.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!