Java多线程 - 创建线程池的方法 - ThreadPoolExecutor和Executors

本文详细介绍了Java线程池的概念、工作原理和实现方式,包括ThreadPoolExecutor构造器参数解析,以及如何通过ExecutorService和Executors创建线程池。通过实例分析了线程池处理Runnable和Callable任务的流程,同时也揭示了使用Executors工具类可能带来的系统风险。
摘要由CSDN通过智能技术生成
文章目录

线程池(重点)

线程池介绍

什么是线程池

线程池就是一个可以复用线程的技术。

不使用线程池的问题:

如果用户每发起一个请求,后台就创建一个新线程来处理,下次新任务来了又要创建新线程,而创建新线程的开销是很大的,这样会严重影响系统的性能。

线程池工作原理:

例如线程池中最多可以允许创建三个工作线程, 也叫核心线程, 前面三个任务来的时候会给前面三个任务单独创建三个线程; 但是后面任务再来的时候, 因为创建的工作线程已达到最大数, 那么后面的任务就会进入任务队列中排队等待; 等前面的任务执行完成, 有空闲的线程的时候使用空闲的线程依次执行任务队列中的任务

在这里插入图片描述

实现线程池的方式

谁代表线程池

JDK 5.0起提供了代表线程池的接口:ExecutorService

如何得到线程池对象

  • 方式一:使用ExecutorService的实现类ThreadPoolExecutor自创建一个线程池对象
  • 方式二:使用Executors(线程池的工具类)调用方法返回不同特点的线程池对象
方式一: 实现类ThreadPoolExecutor
ThreadPoolExecutor构造器的参数

ThreadPoolExecutor的构造器有如下参数

public ThreadPoolExecutor(int corePoolSize,
                          int maximumPoolSize,
                          long keepAliveTime,
                          TimeUnit unit,
                          BlockingQueue<Runnable> workQueue,
                          ThreadFactory threadFactory,
                          RejectedExecutionHandler handler) 

参数介绍:

  • 参数一:指定线程池的线程数量(核心线程): corePoolSize ----> 不能小于0
  • 参数二:指定线程池可支持的最大线程数: maximumPoolSize ----> 最大数量 >= 核心线程数量
  • 参数三:指定临时线程的最大存活时间: keepAliveTime ----> 不能小于0
  • 参数四:指定存活时间的单位(秒、分、时、天): unit ----> 时间单位
  • 参数五:指定任务队列: workQueue ----> 不能为null
  • 参数六:指定用哪个线程工厂创建线程: threadFactory ----> 不能为null
  • 参数七:指定线程忙,任务满的时候,新任务拒绝策略: handler ----> 不能为null

新任务拒绝策略:

策略

详解

ThreadPoolExecutor.AbortPolicy

丢弃任务并抛出RejectedExecutionException异常。是默认的策略

ThreadPoolExecutor.DiscardPolicy

丢弃任务,但是不抛出异常 这是不推荐的做法

ThreadPoolExecutor.DiscardOl

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值