线程池核心参数
前言
创建线程的方式有四种
- 
继承 Thread 类; public class MyThread extends Thread { @Override public void run() { System.out.println(Thread.currentThread().getName() + " run()方法正在执行..."); }
- 
实现 Runnable 接口; public class MyRunnable implements Runnable { @Override public void run() { System.out.println(Thread.currentThread().getName() + " run()方法执行中..."); }
- 
实现 Callable 接口; public class MyCallable implements Callable<Integer> { @Override public Integer call() { System.out.println(Thread.currentThread().getName() + " call()方法执行中..."); return 1; }
- 
使用匿名内部类方式 public class CreateRunnable { public static void main(String[] args) { //创建多线程创建开始 Thread thread = new Thread(new Runnable() { public void run() { for (int i = 0; i < 10; i++) { System.out.println("i:" + i); } } }); thread.start(); } }
通过这几种方式创建的线程,在执行完毕之后都会被销毁,这样频繁的创建和销毁线程是一件很浪费资源到的事情。那么,有没有什么办法解决这个问题呢?通过创建线程池就可以解决这个问题。
线程池四种创建方式?
- Java通过Executors(jdk1.5并发包)提供四种线程池,分别为:- newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
- newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
- newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
- newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
 
线程池的执行原理:

通过线程池创建的线程执行完毕之后并不会销毁,而是会回到线程池继续重复利用,执行其他任务。这里简单介绍一下线程池的几个主要参数:
一、核心参数:
1、corePoolSize(核心线程数)
(1)核心线程会一直存在,即使没有任务执行
(2)当线程数小于核心线程数时,即使有空闲线程,也会一直创建线程直到大道和弦线程树
(3)设置allowCoreThreadTimeout=true(默认false)时,核心线程会超时关闭
2、queueCapacity(任务队列容量)
也叫阻塞队列,当核心线程都在运行,此时再有任务进来,会进入任务队列,排队等待线程执行。
3、maxPoolSize(最大线程数)
(1)线程池里允许存在的最大线程数量
(2)当任务队列已满,且线程数量大于等于核心线程数时,会创建新的线程执行任务
4、keepAliveTime(线程空闲时间)
(1)当线程空闲时间达到keepAliveTime时,线程会退出(关闭),直到线程数等于核心线程数
(2)如果设置了allowCoreThreadTimeout=true,则线程会退出知道线程数等于零
5、allowCoreThreadTimeout(允许核心线程超时)
6、rejectedExcutionHandler(任务拒绝处理器)
(1)当线程数量达到最大线程数,且任务队列已满时,会拒绝任务
(2)调用线程池shutdown()方法后,会等待执行完线程池的任务之后,再shutdown()。如果在调用了shutdown()方法和线程池真正shutdown()之间提交任务,会拒绝新任务。
二、线程池参数默认值
- corePoolSize = 1
- queueCapacity = Integer.MAX_VALUE
- maxPoolSize = Integer.MAX_VALUE
- keepAliveTime = 60秒
- allowCoreThreadTimeout = false
- rejectedExecutionHandler = AbortPolicy()
三、ThreadPoolExecutor(线程池)执行顺序
- 当线程数小于核心线程数时,会一直创建线程直到线程数等于核心线程数;
- 当线程数等于核心线程数时,新加入的任务会被放到任务队列等待执行;
- 当任务队列已满,又有新的任务时,会创建线程直到线程数量等于最大线程数;
- 当线程数等于最大线程数,且任务队列已满时,新加入任务会被拒绝。
 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号