/*
* interface Executor 执行行程接口
* +executor(Runnable object)执行任务
* interface ExecutorService 管理线程接口
* +shutdown()关闭执行器
* +shutdownNow()立即关闭执行器,返回未完成任务清单
* +isShutdown执行器已关闭返回true
* +isTerminated想线程池中所有任务都被终结,返回true
*
* Executors类的静态方法
* +newFixedThreadPool(numberOfThreads:int):ExecutorService 创建一个固定线程数量的线程池,并行执行的线程数量不变,线程当前任务完成后,可以被重用执行另一个任务
* +newCachedThreadPool():ExecutorService 创建一个线程池,按需创建新线程,但当前面创建的线程可用时,则重用它们
*/
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExcutorDemo {
public static void main(String[] args) {
// TODO Auto-generated method stub
/*
* 当n=1时线程1,2,3顺序执行
* 当n=2时线程1,2同时执行,线程3等待,当有线程空闲时,执行线程3
* 当n3时线程1,2,3同时执行
*/
ExecutorService executor=Executors.newFixedThreadPool(3);//创建一个固定3个线程的线程池
executor.execute(new PrintChar('a',50));//执行线程1
executor.execute(new PrintNum(50));//执行线程2
executor.execute(new PrintChar('b',50));//执行线程3
executor.shutdown();//关闭执行器,不在接受新任务
}
/*
* interface Executor 执行行程接口
* +executor(Runnable object)执行任务
* interface ExecutorService 管理线程接口
* +shutdown()关闭执行器
* +shutdownNow()立即关闭执行器,返回未完成任务清单
* +isShutdown执行器已关闭返回true
* +isTerminated想线程池中所有任务都被终结,返回true
*
* Executors类的静态方法
* +newFixedThreadPool(numberOfThreads:int):ExecutorService 创建一个固定线程数量的线程池,并行执行的线程数量不变,线程当前任务完成后,可以被重用执行另一个任务
* +newCachedThreadPool():ExecutorService 创建一个线程池,按需创建新线程,但当前面创建的线程可用时,则重用它们
*/
//任务类
public static class PrintChar implements Runnable{
private char charToPrint;
private int times;
PrintChar(char c,int t)
{
charToPrint=c;
times=t;
}
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0;i<times;i++){
System.out.print(charToPrint);
}
}
}
//任务类
public static class PrintNum implements Runnable{
private int lastNum;
PrintNum(int n){
lastNum=n;
}
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0;i<lastNum;i++){
System.out.print(" "+i);
}
}
}
}
本文介绍如何使用Java的ExecutorService接口创建固定线程数量的线程池,并通过示例演示了不同线程数量下任务的执行情况。展示了如何利用Executors类创建线程池并执行多个任务。
1431

被折叠的 条评论
为什么被折叠?



