Java并发编程学习05—ThreadPool线程池

本文详细介绍了Java的Executor框架,重点讲解了ThreadPoolExecutor的参数、饱和策略、线程池状态以及常见线程池类型。内容涵盖execute()与submit()的区别,以及线程池大小的确定原则。
摘要由CSDN通过智能技术生成

一、Executor框架

1. 框架结构

框架有三部分构成:任务(Runnable/Callable)、任务的执行(Executor)、异步计算的结果(Future)

  • Executor是核心接口类
  • ThreadPoolExecutor/ScheduledThreadPoolEdecutor`可以去执行 Runnable/Callable接口的实现类
  • Future 接口以及 Future 接口的实现类 FutureTask 类都可以代表异步计算的结果,当我们把 Runnable接口 或Callable接口的实现类提交给 ThreadPoolExecutor 或ScheduledThreadPoolExecuto执行。(调用submit() 方法时会返回一个 FutureTask 对象)

2.框架使用示意图

二、ThreadPoolExecutor类(重点)

ThreadPoolExecutor几个参数:

  • **corePoolSize 😗*核心线程数
  • maximumPoolSize : 最大线程数
  • **workQueue😗*当前运行的线程数
  • keepAliveTime:当线程数大于核心线程数时,多余的空闲线程存活的最长时间
  • unit : keepAliveTime 参数的时间单位
  • threadFactory:Thread线程
  • handler :饱和策略

1.饱和策略

  • ThreadPoolExecutor.AbortPolicy:抛出(拒绝新任务的处理)
  • ThreadPoolExecutor.CallerRunsPolicy:直接在调用execute方法的线程中运行(run)被拒绝的任务,如果执行程序已关闭,则会丢弃该任务
  • ThreadPoolExecutor.DiscardPolicy 不处理新任务,直接丢弃掉
  • ThreadPoolExecutor.DiscardOldestPolicy 此策略将丢弃最早的未处理的任务请求

2. Runnable+ThreadPoolExecutor

Runable接口的实现类:

import java.util.Date;

/**
 * 这是一个简单的Runnable类,需要大约5秒钟来执行其任务。
 * @author shuang.kou
 */
public class MyRunnable implements Runnable {
   

    private String command;

    public MyRunnable(String s) {
   
        this.command = s;
    }

    @Override
    public void run() {
   
        System.out.println(Thread.currentThread().getName() + " Start. Time = " + new Date());
        processCommand();
        System.out.println(Thread.currentThread().getName() + " End. Time = " + new Date());
    }

    private void processCommand() {
   
        try {
   
            Thread.sleep(5000);
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }
    }

    @Override
    public String toString() {
   
        return this.command;
    }
}

ThreadPoolExecutor执行runnable接口的实现类:

import
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值