• Executor框架


    前言

    在一些场景,我们常常会用到多线程,但是线程的管理又比较麻烦。所以我们通常使用线程池来进行线程的管理,而今天我们将介绍一个java中常常 用来创建线程池的框架Executor框架。

    Executor框架简介

    在HotpSpot vm 模型中,java线程被一对一映射为本地操作系统线程。Java线程启动的时候会创建一个相对应的本地线程,当java线程中止的时候,这个操作系统的线程也会被回收。

    Executor框架主要结构大致由三部分组成:
    1.任务:包括被执行的任务需要实现的接口:Runnable接口或Callable接口
    2.任务的执行:包括执行任务机制的核心接口Executor,以及继承Executor接口的ExecutorService接口。
    3.异步计算结果:包括接口Fature和实现Fature接口的FatureTask类

    Executor框架成员大致有四个
    1.ThreadPoolExecutor:基本的线程池,一般由Excutors创建。大致会有三个类型
    (1)FixedThreadPool,有着固定数量线程的线程池,通过Excutors的newFixedThreadPool方法创建

    在这里插入图片描述
    (2)SingleThreadExecutor,只有单个线程的线程池,通过Excutors的newSingleThreadExecutor方法创建
    在这里插入图片描述
    (3)CachedThreadPool,大小无界的线程池,根据需要创建线程,通过Excutors的newCachedThreadPool方法创建
    在这里插入图片描述
    由上面大家可以看出,他们本质其实都还是ThreadPoolExecutor,不过是对ThreadPoolExecutor(之前的文章有详细的介绍)的一些核心参数做了控制,形成不同类型的线程池。

    2.ScheduledThreadPoolExecutor:一个支持定时任务调度的线程池。
    在这里插入图片描述
    它继承了线程池和定时任务调度服务,所以它既是线程池,又具有定时任务调度的特性。
    ScheduledThreadPoolExecutor也有两种类型
    (1)ScheduledThreadPool,支持若干线程的线程池,通过Excutors的newScheduledThreadPool方法创建
    在这里插入图片描述
    (2)SingleThreadScheduledExecutor,只包含一个线程的线程池,通过Excutors的newSingleThreadScheduledExecutor方法创建
    在这里插入图片描述

    3.Fature接口:Fature接口和实现Fature接口的FatureTask类用来表示异步计算结果
    4.Runnable接口和Callable接口:被执行的任务需要实现的接口

    ScheduledThreadPoolExecutor和ThreadPoolExecutor对比

    ScheduledThreadPoolExecutor继承ThreadPoolExecutor,所以大致的基本结构和ThreadPoolExecutor还是一样的。但是为了实现周期性执行任务,ScheduledThreadPoolExecutor做了一些特殊处理,主要有三个方面
    1.使用DelayQueue作为任务队列
    2.获取任务方式不同:之前从队列获取任务一般是根据先进先出原则,现在获取任务根据设置的周期时间。
    3.执行任务周期后增加了额外的操作:需要不断的修改执行任务的时间

    总结

    本篇文章介绍了Executor框架的整体结构和成员组件。希望读者阅读文章之后,能够对Executor框架有一个深入的了解,同时也希望本章内容有助于读者更熟练的使用Executor框架。

  • 相关阅读:
    基于人工智能的智能化指挥决策和控制
    Go语言实践模式 - 函数选项模式(Functional Options Pattern)
    自己动手实现一个深度学习算法——三、神经网络的学习
    【iOS】iphone 短信标记未读 bug/ 永远清不干净的红点未读提示 /总结四大解决方案,总有N个适合你
    界面跳转(生命周期易混场景)
    JavaScript面向对象学习深拷贝、浅拷贝(三)
    Windows系统下制作Windows Server系统U盘启动及安装指导
    代码审计基础php_bugs
    vivo面试-Java
    Koa 6 响应(Response)
  • 原文地址:https://blog.csdn.net/qq_41820066/article/details/128193520