线程池

作者: 策马踏清风 | 来源:发表于2020-08-26 21:31 被阅读0次

降低线程创建和销毁的消耗,提高速度,节约资源,线程可管理。

参数含义

  • int corePoolSize核心线程数
  • int maximumPoolSize最大线程数
  • long keepAliveTime空闲线程存活时间
  • workQueue任务队列
  • threadFactory创建线程的工厂,主要赋予名字
  • RejectedExcutionHandler线程池饱和策略
  1. AbortPolicy抛出异常,默认
  2. CallerRunsPolicy调用者线程执行
  3. DiscardOldestPolicy丢弃最老的任务
  4. DiscardPolicy直接丢弃

实现自己的饱和策略,实现RejectedExcutionHandler就行,保存到数据库之类的。

提交任务

  • execute(Runnable command)不需要返回
  • Future<T> submit(Callable<T> task)有返回

最佳线程数

  • CPU密集型,Runtime.getRuntime().availableProcessors() + 1最大核心数+1
  • IO密集型,尽量大,可以是CPU数 * 2

预定义线程池(全部实现ExecutorService接口)

  • FixedThreadPool
  • SingleThreadExecutor
  • CachedThreadPool
  • WorkStealingPool基于fork/join
  • ScheduledThreadPoolExecutor定时执行的任务,可以指定抛出异常,不影响线程执行。
  • newSingleThreadScheduledExecutor包含一个线程,只需要单个线程执行周期任务,保证任务执行顺序
  1. schedule执行一次,可以延时执行
  2. scheduleAtFixedRate提交固定时间执行任务
  3. scheduleWhithFixedDelay提交固定延时间隔执行的任务
  • scheduleAtFixedRate任务超时,当前一个任务超出下个任务的超时时间,下个任务会在上一个执行后马上执行。

自定义线程池

  • new ThreadPoolExecutor(...)

CompletionService

  • 用于接收线程池返回结果(先结束的先拿)
// 包装线程池
CompletionService<Integer> cService = new ExcutorCompletionService<>(pool);
// 提交若干任务
cService.submit(new WorkTask(..));
cService.submit(new WorkTask(..));
// 按照执行速度获取执行结果
cService.take().get();
cService.take().get();
  • 内部包装了task会将执行成功的结果放到内部维护的队列中。

相关文章

  • java线程池

    线程VS线程池 普通线程使用 创建线程池 执行任务 执行完毕,释放线程对象 线程池 创建线程池 拿线程池线程去执行...

  • java----线程池

    什么是线程池 为什么要使用线程池 线程池的处理逻辑 如何使用线程池 如何合理配置线程池的大小 结语 什么是线程池 ...

  • Java线程池的使用

    线程类型: 固定线程 cached线程 定时线程 固定线程池使用 cache线程池使用 定时调度线程池使用

  • Spring Boot之ThreadPoolTaskExecut

    初始化线程池 corePoolSize 线程池维护线程的最少数量keepAliveSeconds 线程池维护线程...

  • 线程池

    1.线程池简介 1.1 线程池的概念 线程池就是首先创建一些线程,它们的集合称为线程池。使用线程池可以很好地提高性...

  • 多线程juc线程池

    java_basic juc线程池 创建线程池 handler是线程池拒绝策略 排队策略 线程池状态 RUNNIN...

  • ThreadPoolExecutor线程池原理以及源码分析

    线程池流程: 线程池核心类:ThreadPoolExecutor:普通的线程池ScheduledThreadPoo...

  • 线程池

    线程池 [TOC] 线程池概述 什么是线程池 为什么使用线程池 线程池的优势第一:降低资源消耗。通过重复利用已创建...

  • java 线程池使用和详解

    线程池的使用 构造方法 corePoolSize:线程池维护线程的最少数量 maximumPoolSize:线程池...

  • 线程池

    JDK线程池 为什么要用线程池 线程池为什么这么设计 线程池原理 核心线程是否能被回收 如何回收空闲线程 Tomc...

网友评论

      本文标题:线程池

      本文链接:https://www.haomeiwen.com/subject/bvgfsktx.html