• 线程应用实例


    一.等待超时模式

    场景:调用一个方法时等待一段时间,如果该方法能够在给定的时间之内得到结果,将立即返回,反之,如果超时返回默认结果。

    二.数据库连接池

    连接池的定义:构造函数初始化连接的最大上限,通过一个双向队列来维护连接,调用方需要先调用fetchConnection(long)方法来指定多少毫秒内超时获取连接,当连接使用完成后,需要调用releaseConnection(Connection)方法将连接放回连接池。

    三.线程池技术

    3.1线程池的作用

            面对 成千上万的任 务递 ,如果还是采用一个任 一个 线 程的方式,那么将会 建数以万 线 程, 不是一个好的选择,因为这会使操作系统频繁的进行线程上下文切换,无故增加系统的负载,而线程的创建和消亡都是需要耗费系统资源的,也无疑浪费了系统资源。
    线程池很好的解决了这个问题,它预先创建了若干的线程,并且不能由用户直接对线程的创建进行控制

     3.2线程池的优势

    • 降低资源消耗
    • 提高响应速度
    • 提高线程的可管理性

    3.3 线程池中的几个参数

    1: 核心线程数(corePoolSize)
    核心线程数的设计需要依据任务的处理时间和每秒产生的任务数量来确定,例如:执行一个任务需要0.1秒,系统百分之80的时间每秒都会产生100个任务,那么要想在1秒内处理完这100个任务,就需要10个线程,此时我们就可以设计核心线程数为10;当然实际情况不可能这么平均,所以我们一般按照8020原则设计即可,既按照百分之80的情况设计核心线程数,剩下的百分之20可以利用最大线程数处理;
    2:任务队列长度(workQueue)
    任务队列长度一般设计为:核心线程数/单个任务执行时间*2即可;例如上面的场景中,核心线程数设计为10,单个任务执行时间为0.1秒,则队列长度可以设计为200;
    3:最大线程数(maximumPoolSize)
    最大线程数的设计除了需要参照核心线程数的条件外,还需要参照系统每秒产生的最大任务数决定:例如:上述环境中,如果系统每秒最大产生的任务是1000个,那么,最大线程数=(最大任务数-任务队列长度)*单个任务执行时间;既: 最大线程数=(1000-200)*0.1=80个;
    4:最大空闲时间(keepAliveTime)
    这个参数的设计完全参考系统运行环境和硬件压力设定,没有固定的参考值,用户可以根据经验和系统产生任务的时间间隔合理设置一个值即可;

    3.4线程池工作流程

     

    3.5Executor和Executors的区别

    Executor 接口对象能执行我们的线程任务;

    Executors 工具类的不同方法按照我们的需求创建了不同的线程池,来满足业务的需求。

    ExecutorService 接口继承了Executor接口并进行了扩展,提供了更多的方法,我们能够获得任务执行的状态并且可以获取任务的返回值。

     

    3.6你知道怎么创建线程池吗?

    ThreadPoolExecutor 

     

     

  • 相关阅读:
    Vue 简单快速入门
    JAVASE零基础到高级教程(1)------ 集成开发环境安装使用
    亚马逊测评术语有哪些?
    Web前端—移动Web第四天(媒体查询、Bootstrap、综合案例-alloyTeam)
    【C++】3-1.2.4 函数通过引用传参
    uniapp
    【开发教程9】疯壳·开源蓝牙心率防水运动手环-心率监测
    20 行为型模式-策略模式
    1.代码审计大致规则
    webpack优化系列三:vue子目录路径更改---publicPath
  • 原文地址:https://blog.csdn.net/m0_62902168/article/details/125490181