线程池核心参数

前言

创建线程的方式有四种

  • 继承 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并发包)提供四种线程池,分别为:
    1. newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
    2. newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
    3. newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
    4. 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(线程池)执行顺序

  • 当线程数小于核心线程数时,会一直创建线程直到线程数等于核心线程数;
  • 当线程数等于核心线程数时,新加入的任务会被放到任务队列等待执行;
  • 当任务队列已满,又有新的任务时,会创建线程直到线程数量等于最大线程数;
  • 当线程数等于最大线程数,且任务队列已满时,新加入任务会被拒绝。
posted @ 2021-12-15 18:00  ThisTFF  阅读(2878)  评论(1)    收藏  举报