via: http://blog.csdn.net/truong/article/details/40227435
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Test {
public static void main(String args[]) throws InterruptedException {
ExecutorService exe = Executors.newFixedThreadPool(50);
for (int i = 1; i <= 5; i++) {
exe.execute(new SubThread(i));
}
exe.shutdown();
while (true) {
if (exe.isTerminated()) {
System.out.println("结束了!");
break;
}
Thread.sleep(200);
}
}
}
上面是主线程的代码,创建了一个能同时执行2个线程的线程池,并投入5个线程,当5个线程都执行完毕后打印---“结束了!”字符串。
exe.shutdown();该方法在加入线程队列的线程执行完之前不会执行。
exe.isTerminated();当shutdown()或者shutdownNow()执行了之后才会执行,并返回true。
在上面的代码中必须有exe.isTerminated()的判断,否则在投入5个线程到线程池后会直接打印:“结束了”。不能达到我们想要的效果。
通过while(true)循环判断exe.isTerminated()重生之大文豪的值,为了防止过多的判断浪费资源,可设置线程睡眠Thread.sleep(200);
正是由于这个睡眠,所以当所有线程池中的线程都执行完后,有可能延迟200ms才执行"结束了"语句。这个参数越小延迟越小,结果越准确。
下面是子线程,子线程只是简单的将数字i打印出来;
public class SubThread extends Thread{
private final int i;
public SubThread(int i){
this.i = i;
}
@Override
public void run(){
System.out.println(i);
}
}
执行结果:
run:
3
1
4
5
2
结束了!
成功构建 (总时间: 2 秒)
子线程执行顺序不能控制,所以输出的结果是乱序的。
via: http://www.tuicool.com/articles/ZvAFny
2 使用Thread的join()等待所有的子线程执行完毕,主线程在执行
实现 如下:
import java.util.Vector;
public class ThreadSubMain2 {
public static void main(String[] args) {
Vector<Thread> threads = new Vector<Thread>(); // 使用线程安全的Vector
for (int i = 0; i < 10; i++) {
Thread iThread = new Thread(new Runnable() {
public void run() {
try { Thread.sleep(1000); // 模拟子线程任务 } catch (InterruptedException e) { }
System.out.println("子线程" + Thread.currentThread() + "执行完毕");
}
});
threads.add(iThread);
iThread.start();
}
for (Thread iThread : threads) {
try { // 等待所有线程执行完毕
iThread.join();
} catch (InterruptedException e) { e.printStackTrace(); }
}
System.out.println("主线执行。");
}
}
执行结果如下:
子线程Thread[Thread-1,5,main]执行完毕
子线程Thread[Thread-2,5,main]执行完毕
子线程Thread[Thread-0,5,main]执行完毕
子线程Thread[Thread-3,5,main]执行完毕
子线程Thread[Thread-4,5,main]执行完毕
子线程Thread[Thread-9,5,main]执行完毕
子线程Thread[Thread-7,5,main]执行完毕
子线程Thread[Thread-5,5,main]执行完毕
子线程Thread[Thread-8,5,main]执行完毕
子线程Thread[Thread-6,5,main]执行完毕
主线执行。
这种方式符合要求,它能够等待所有的子线程执行完,主线程才会执行。
3 使用 ExecutorService 线程池,等待所有任务执行完毕再执行主线程, awaitTermination 。
awaitTermination(long timeout,TimeUnit unit)
请求关闭、发生超时或者当前线程中断,无论哪一个首先发生之后,都将导致阻塞,直到所有任务完成执行。
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
public class ThreadSubMain3 {
public static void main(String[] args) {
ExecutorService threadPool = Executors.newCachedThreadPool(); // 定义一个缓冲的线程值 线程池的大小根据任务变化
for (int i = 0; i < 10; i++) {
threadPool.execute(new Runnable() {
public void run() {
try {
Thread.sleep(1000); // 模拟子线程任务
} catch (InterruptedException e) { }
System.out.println("子线程" + Thread.currentThread() + "执行完毕");
}
});
}
threadPool.shutdown(); // 启动一次顺序关闭,执行以前提交的任务,但不接受新任务。
try {
// 请求关闭、发生超时或者当前线程中断,无论哪一个首先发生之后,都将导致阻塞,直到所有任务完成执行
// 设置最长等待10秒
threadPool.awaitTermination(10, TimeUnit.SECONDS);
} catch (InterruptedException e) { e.printStackTrace(); }
System.out.println("主线执行。");
}
}
执行结果如下:
子线程Thread[pool-1-thread-4,5,main]执行完毕
子线程Thread[pool-1-thread-1,5,main]执行完毕
子线程Thread[pool-1-thread-7,5,main]执行完毕
子线程Thread[pool-1-thread-6,5,main]执行完毕
子线程Thread[pool-1-thread-5,5,main]执行完毕
子线程Thread[pool-1-thread-2,5,main]执行完毕
子线程Thread[pool-1-thread-3,5,main]执行完毕
子线程Thread[pool-1-thread-8,5,main]执行完毕
子线程Thread[pool-1-thread-10,5,main]执行完毕
子线程Thread[pool-1-thread-9,5,main]执行完毕
主线执行。
这种方法和方法2一样,将等待所有子线程执行完毕之后才执行主线程。
相关推荐
中文文档,其目录如下: 线程中一些基本术语和概念 线程之间的通讯 Java线程调度 线程池 工作队列
主要介绍了Java 判断线程池所有任务是否执行完毕的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
构建线程池,提高线程访问速度,非常经典,非常好的原代码
java简单线程池的实现,使用jdk的Executors.newFixedThreadPool方法来实现固定大小线程池
JavaThreaddemo_DEMO_tidecme_线程池Java_源码.zip
_JAVA线程池介绍以及简单实例.doc
Java线程池的代码,不是整一个项目,仅供参考
java多线程,线程池,lambda表达式
Java并发编程相关源码集 包括多任务线程
AsyncHttpClient是对HttpClient的再次包装。AsyncHttpClient的特点有:发送异步HTTP请求、HTTP请求发生在UI线程之外、内部采用了线程池来处理并发请求。而且它使用起来比HttpClient更加简便。
这是有关于Java线程池的demo,仅供参考,不是全部代码
Java线程池的几种实现方法和区别介绍 使用:LinkedBlockingQueue实现线程池讲解
private String testTable = "" // 测试连接是否可用的测试表名,默认没有测试表 private int initialConnections = 10 // 连接池的初始大小 private int incrementalConnections = 5 // 连接池自动增加的大小 ...
简单的线程池程序+中文文档 包结构: com.tangkai.threadpool --SimpleThread.java 工作线程 --TestThreadPool.java 程序入口 --ThreadPoolManager.java 线程池管理类
主要介绍了Java判断线程池线程是否执行完毕,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
Java实现通用线程池
一个比较简单的线程池至少应包含线程池管理器、工作线程、任务队列、任务接口等部分。其中线程池管理器(ThreadPool Manager)的作用是创建、销毁并管理线程池,将工作线程放入线程池中;工作线程是一个可以循环执行...
ThreadPool 线程池类 DEFAULT_POOL_SIZE 默认线程池大小 threadPool 线程队列 taskQueue 任务队列 poolSize 自定义线程池...通过构造启动该线程池,调用addTask 方法将task任务传入,线程池会自动分配线程去执行任务
Java线程池使用说明Java线程池使用说明Java线程池使用说明
java 线程池 java 线程池 java 线程池 java 线程池