自定义线程池
/*
* 线程池概述:创建线程是需要消耗系统资源的,如果用完一个线程之后就让其释放,下一次再使用线程需要再次创建,效率比较低,也比较消耗系统资源。
* 这时候可以创建一个线程池,把用完的线程放到这个池子里面去,如果其它地方需要使用线程可以直接从这个池子里面取就可以了。
* 线程池如何实现呢?
* JDK1.5之后就内置了,使用Executors的静态方法就可以获取线程池,当然你也可以通过ThreadPoolExecutor这个类自定义线程池。
*/
public class ThreadPoolDemo {
public static void main(String[] args) {
//1.创建线程池
//public static ExecutorService newCachedThreadPool()创建一个线程池,空闲线程最多存活60s。
ExecutorService threadPool = Executors.newCachedThreadPool();
//2.创建Runnable
Runnable take = new Runnable(){
@Override
public void run() {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"执行了");
}
};
//3.直接把task任务交给线程池,线程池内部会自动的取线程执行task任务
//public void execute(Runnable command)在将来某个时间执行给定任务。
threadPool.execute(take);//pool-1-thread-1执行了
//4.关闭 void shutdown()启动一次顺序关闭,执行以前提交的任务,但不接受新任务。如果已经关闭,则调用没有其他作用。
threadPool.shutdown();
//threadPool.execute(take);
//异步加载
submit(threadPool);
System.out.println("over");
}
private static void submit(ExecutorService threadPool) {
/*
* public <T> Future<T> submit(Callable<T> task)
提交一个返回值的任务用于执行,返回一个表示任务的未决结果的 Future。该 Future 的 get 方法在成功完成时将会返回该任务的结果。
*/
Future future = threadPool.submit(new Callable<String>(){
@Override
public String call() throws Exception {
return "今天是美好的一天";
}
});
}
}