线程池

xiaoxiao2021-02-28  13

线程池的概念与Executors类的应用

创建固定大小的线程池 创建缓存线程池 创建单一线程池(线程死掉会重新启动)

代码

package mutithread.threadpool; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class ThreadPoolTest { public static void main(String[] args) { // 创建固定线程池 // ExecutorService threadPool = Executors.newFixedThreadPool(3); // 创建缓存线程池 // ExecutorService threadPool = Executors.newCachedThreadPool(); // 创建只有一个线程的线程池 好处是这个线程死了 会自动补齐一个线程 线程死后会重新启动 ExecutorService threadPool = Executors.newSingleThreadExecutor(); for (int i = 0; i < 10; i++) { final int task = i; threadPool.execute(new Runnable() { @Override public void run() { for (int i = 0; i < 2; i++) { System.out.println(Thread.currentThread().getName() + " loop of " + i + " for task of " + task); } } }); } threadPool.shutdown(); System.out.println("10 tasks have commit"); } }

关闭线程池

shutdown() 和 shutdownNow() 的比较 shutdown()  当线程池调用该方法时,线程池的状态则立刻变成SHUTDOWN状态。此时,则不能再往线程池中添加任何任务,否则将会抛出RejectedExecutionException异常。但是,此时线程池不会立刻退出,直到添加到线程池中的任务都已经处理完成,才会退出 shutdownNow() 根据JDK文档描述,大致意思是:执行该方法,线程池的状态立刻变成STOP状态,并试图停止所有正在执行的线程,不再处理还在池队列中等待的任务,当然,它会返回那些未执行的任务。 它试图终止线程的方法是通过调用Thread.interrupt()方法来实现的,但是大家知道,这种方法的作用有限,如果线程中没有sleep 、wait、Condition、定时锁等应用, interrupt()方法是无法中断当前的线程的。所以,ShutdownNow()并不代表线程池就一定立即就能退出,它可能必须要等待所有正在执行的任务都执行完成了才能退出。 shutdown()本身的执行很快,执行完后线程池可能仍处于运行中, 而awaitTermination(Long.MAX_VALUE, TimeUnit.MINUTES)是一个阻塞方法。它必须等线程池退出后才会结束自身 可以使用这两个方法组合来确保任务都被处理后 主线程再进行执行

用线程池启动定时器

// 5秒以后爆炸 Executors.newScheduledThreadPool(3).schedule(new Runnable() { @Override public void run() { System.out.println("bombing!"); } }, 5, TimeUnit.SECONDS); // 5秒以后爆炸后每隔两秒爆炸一次 Executors.newScheduledThreadPool(3).scheduleAtFixedRate(new Runnable() { @Override public void run() { System.out.println("bombing!"); } }, 5, 2, TimeUnit.SECONDS);
转载请注明原文地址: https://www.6miu.com/read-1250073.html

最新回复(0)