iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >如何理解线程池的工作原理
  • 485
分享到

如何理解线程池的工作原理

2024-04-02 19:04:59 485人浏览 独家记忆
摘要

本篇内容主要讲解“如何理解线程池的工作原理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解线程池的工作原理”吧!什么是线程池?「小田螺」 勤勤恳恳,任劳任

本篇内容主要讲解“如何理解线程池的工作原理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解线程池的工作原理”吧!

什么是线程池?

「小田螺」 勤勤恳恳,任劳任怨,夜以继日地工作着。终于有一天,他晋升为公司的主管,负责公司日常业务。

风轻云淡的一天,老板找到了小田螺,“我们公司员工越来越多了,我想搞个「员工管理系统」,你那边安排一下哈,要在一个月后完成。”  小田螺拍拍胸口,没问题!

因为当前公司还没有程序员,所以小田螺快马加鞭打开「猪八戒网」,提交员工管理系统需求,等待不久,「开发者(名字,线程A)」  接单,谈好合同,开始开发,系统交付...一系列流程下来,并且一个月过后,一个五脏俱全的员工管理系统终于完成了...老板对此大加赞赏~

过了不久,老板再次发话,“公司越来越多人迟到了,我们再搞个「考勤系统」吧!"  小田螺接到任务,马上又开始上猪八戒网,提需求找人开发,这次来了「线程B接单」......

逝者如斯,月底了,老板又提出开发个薪酬系统需求...小田螺听了头皮发麻,one day  day的,重复去网上找人开发!“为了节省成本,不如我们雇佣几个程序员(线程a,b,c),成立自己的IT技术部门吧!我们就管IT部门叫「线程池」吧!”老板听了,一拍即合!!!

线程池就是管理线程的池子,当有任务要处理时,不用频繁创建新线程,而是从池子拿个线程出来处理。当任务执行完,线程并不会被销毁,而是在等待下一个任务。因此可以节省资源,提高响应速度。

什么是核心线程?

「线程池」IT部门成立后,雇佣了几个与公司有正式合同关系的员工a,b,c,「小田螺」管他们几个正式员工做「核心线程」。当老板提一个需求过来,小田螺就把需求分配给「手上没活干」的线程处理...

什么是阻塞队列?

一天早上,老板睡眼惺忪。来到公司后,一口气提了「四个需求」,a,b,c  按顺领完任务后,发现还剩余一个需求任务。这个怎么安排呢?难道又去「猪八戒兼职网」找人嘛?成立了「线程池IT部门」,还去找人(找线程干活),会被人笑落大牙的!

聪明的小田螺想到一个好办法,我们可以搞个DPMS需求池,把还没分配的需求,放进待完成的DPMS需求池里面吧,等到a,b,c谁先干完活,再把这个任务领走。这个DPMS需求池,我们给它取名「阻塞队列」,英文名叫「WorkQueue」吧!

什么是非核心线程?

又在一个晴空万里的午后,老板喝了一杯咖啡,闲来没事,就跑去「阻塞队列」(DPMS需求池)看看,一看就傻帽了!!需求池堆积了几十个需求,排期都是满满的了。老板马上叫「小田螺进来办公室」,以商量如何处理这些需求任务。

“要不,我们雇佣多几个员工(搞多几个「核心线程」)?” “不行不行,公司财务「开销」有点大!”

“要不然,我们要求业务提少点任务需求?(「请求少点」)” “你是不是傻,请求少点,不是自断财路嘛?你回家想想办法先吧!!”老板放大了他的嗓门~

小田螺回家闭目让神,每天早早就睡觉,两耳不闻窗外事...终于有一天,在一个梦香里,他想到了一个好办法。

“老板,我们可以去别的公司(「外包公司」)雇佣几个员工(假设名字为d,e,f,g)一段时间,让它们来做「DPMS需求池(阻塞队列)」  里面的需求。等到做完需求,再派他们回去就好啦。” 老板一听就乐了,这个方案好,心里美滋滋:「需求的活有人干了,公司财务又省钱,两全其美呀」~  这几个派遣来的外包员工(d,e,f,g),我们就把它叫做「非核心线程」吧。

什么是空闲时间?

自从来了d,e,f,g外包员工(「非核心线程」),老板长舒一口气,这么多活,终于有人干了。

但是呢,又有一天,到了7点所谓的下班时间,老板走出办公室,发现「线程池」IT部门的员工,都走得七七八八了。心里一怒:「这帮粉肠,怎么一到下班时间就跑,工作这么不饱和了」?他随手点进DPMS需求池,才发现,原来需求都被做完了。。。还有一堆外包同事(非核心线程)要发工资呢,这波亏大了~

第二天,小田螺被「秘密」叫进了老板办公室,既然DPMS需求池都已经没需求了。我们准备派外包同事(非核心线程)回去吧?但是呢一般,需求一没有,就马上让他们回去(「线程回收」),如果需求一下子又来,就有点hold不住了...

“要不酱紫,我们等需求池空的时候,隔个15天还是10天,再让外包同事(「非核心线程」)回去吧?”  这个定义的15天或者10天,就是「线程空闲存活时间」啦

什么是饱和策略

在临近双11的时候,不仅老板提了良多需求,新来的运营小姐姐们,也提了好多好多的需求。新需求如源头活水,滚滚的来~

首先呢,「线程池」IT部门a,b,c三个正式员工(核心线程)都忙于处理需求(「请求」),接着,DPMS需求池(「阻塞队列」)也被挤满了,最后呢,连d,e,f,g外包同事(「非核心线程」)也忙得不可开交。

这时候,需求还是做不完,怎么办呢?双11赶着上线呢?小田螺愁眉苦脸,从「潮起愁到潮落」...

没办法了,只能动用「饱和策略」啦。比如「丢弃需求任务」?「抛异常,告诉老板别加需求了」?「丢弃需求池最老的需求任务」?还是「交给提需求的人自己处理」?

最后老板决定,「拒绝再提新的需求」,于是「线程池」IT部门还是正常运行~

线城池的饱和策略事件,主要有四种类型

  • AbortPolicy(抛出一个异常,默认的)

  • DiscardPolicy(新提交的任务直接被抛弃)

  • DiscardOldestPolicy(丢弃队列里最老的任务,将当前这个任务继续提交给线程池)

  • CallerRunsPolicy(交给线程池调用所在的线程进行处理,即将某些任务回退到调用者)

线程池工作原理流程图 & 源码概览

故事讲完啦,再复习下线程池工作流程图吧~

如何理解线程池的工作原理

有兴趣的朋友,源码也可以看下哈~

if (command == null)             throw new NullPointerException();         int c = ctl.get();         //判断当前活跃线程数是否小于corePoolSize         if (workerCountOf(c) < corePoolSize) {             //如果小于,则调用addWorker创建线程执行任务             if (addWorker(command, true))                 return;             c = ctl.get();         }         //如果大于等于corePoolSize,则将任务添加到workQueue队列。         if (isRunning(c) && workQueue.offer(command)) {             int recheck = ctl.get();             if (! isRunning(recheck) && remove(command))                 reject(command);             else if (workerCountOf(recheck) == 0)                 addWorker(null, false);         }         //如果放入workQueue队列失败,则创建非核心线程执行任务             else if (!addWorker(command, false))             //(如果这时创建线程失败(当前线程数大于等于maximumPoolSize时))             调用reject拒绝接受任务             reject(command);

到此,相信大家对“如何理解线程池的工作原理”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 如何理解线程池的工作原理

本文链接: https://www.lsjlt.com/news/84456.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何理解线程池的工作原理
    本篇内容主要讲解“如何理解线程池的工作原理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解线程池的工作原理”吧!什么是线程池「小田螺」 勤勤恳恳,任劳任怨...
    99+
    2024-04-02
  • java线程池的工作原理
    这篇文章主要讲解了“java线程池的工作原理”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java线程池的工作原理”吧!一、线程池创建先看一下ThreadPoolExecutor参数最全的构...
    99+
    2023-05-30
  • 线程池的工作原理是什么
    这篇文章主要讲解了“线程池的工作原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“线程池的工作原理是什么”吧!线程池的自我介绍我是一个线程池(Thre...
    99+
    2024-04-02
  • 详解Java线程池的使用及工作原理
    目录一、什么是线程池?二、线程池要解决什么问题?三、线程池的使用四、常用阻塞队列五、线程工厂六、拒绝策略七、线程池的执行逻辑八、execute()方法九、执行流程一、什么是线程池? ...
    99+
    2024-04-02
  • 理解Golang中线程与协程的工作原理
    Golang中线程与协程的工作原理 在Go语言(Golang)中,线程和协程是非常重要的概念,它们是并发编程的基本组成部分。理解它们的工作原理对于开发高效的并发程序非常重要。本文将深入...
    99+
    2024-02-29
    golang 线程 协程 go语言 并发访问
  • 线程池的原理和作用是什么
    这篇文章主要讲解了“线程池的原理和作用是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“线程池的原理和作用是什么”吧!一、为什么需要线程池在实际使用中,线...
    99+
    2024-04-02
  • 如何理解蜘蛛池的原理和作用
    这篇文章主要讲解了“如何理解蜘蛛池的原理和作用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解蜘蛛池的原理和作用”吧!蜘蛛池是一种通过利用大型平台权重来获得百度收录以及排名的一种程序,...
    99+
    2023-06-10
  • Java线程池工作原理和使用方法是什么
    这篇文章主要介绍“Java线程池工作原理和使用方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java线程池工作原理和使用方法是什么”文章能帮助大家解决问题。1. 为什么要使用线程池使用线程...
    99+
    2023-07-04
  • 工作中禁止使用Executors快捷创建线程池原理详解
    目录问题?1.1 newFixedThreadPool的潜在问题1.2 newSingleThreadExecutor的潜在问题?1.3 newCachedThreadPool的潜在...
    99+
    2022-11-13
    禁止用Executors创建线程池 Executors 线程池
  • 线程池的原理与实现详解
    一. 线程池的简介通常我们使用多线程的方式是,需要时创建一个新的线程,在这个线程里执行特定的任务,然后在任务完成后退出。这在一般的应用里已经能够满足我们应用的需求,毕竟我们并不是什么...
    99+
    2022-11-15
    线程池 原理
  • 深入理解Java编程线程池的实现原理
    在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题:如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间...
    99+
    2023-05-30
    java 线程池 ava
  • SpringBoot线程池和Java线程池的使用和实现原理解析
    目录SpringBoot线程池和Java线程池的用法和实现原理使用默认的线程池方式一:通过@Async注解调用方式二:直接注入 ThreadPoolTaskExecutor...
    99+
    2023-05-15
    SpringBoot线程池和Java线程池用法 SpringBoot线程池
  • android线程池的原理是什么
    Android线程池的原理是通过管理和调度线程来实现并发执行任务的机制。线程池主要由线程池管理器、工作队列和线程池的线程组成。线程池...
    99+
    2023-09-23
    android
  • 详解Java线程池和Executor原理的分析
    详解Java线程池和Executor原理的分析线程池作用与基本知识在开始之前,我们先来讨论下“线程池”这个概念。“线程池”,顾名思义就是一个线程缓存。它是一个或者多个线程的集合,用户可以把需要执行的任务简单地扔给线程池,而不用过多的纠结与执...
    99+
    2023-05-31
    java 线程池 executor
  • cpu流水线工作原理
    CPU流水线工作原理是指将处理器的执行过程分为多个阶段,每个阶段专门处理某一类指令操作,并且这些阶段可以并行执行,从而提高处理器的效...
    99+
    2023-09-20
    cpu
  • java连接池的工作原理是什么
    连接池是一种管理数据库连接的技术,它在应用程序初始化时创建一定数量的数据库连接并保存在连接池中,应用程序需要数据库连接时,直接从连接...
    99+
    2023-09-13
    java
  • 手把手带你理解java线程池之工作队列workQueue
    目录ArrayBlockingQueueSynchronousQueueLinkedBlockingDequeLinkedBlockingQueueDelayDequeLinkedT...
    99+
    2024-04-02
  • Java concurrency线程池之线程池原理(二)_动力节点Java学院整理
    线程池示例在分析线程池之前,先看一个简单的线程池示例。import java.util.concurrent.Executors;import java.util.concurrent.ExecutorService;public clas...
    99+
    2023-05-31
    java concurrency 线程池
  • Java concurrency线程池之线程池原理(三)_动力节点Java学院整理
    线程有5种状态:新建状态,就绪状态,运行状态,阻塞状态,死亡状态。线程池也有5种状态;然而,线程池不同于线程,线程池的5种状态是:Running, SHUTDOWN, STOP, TIDYING, T...
    99+
    2023-05-31
    java concurrency 线程池
  • Java线程池实现原理总结
    目录一、线程池参数二、线程池执行流程三、四种现成的线程池要理解实现原理,必须把线程池的几个参数彻底搞懂,不要死记硬背 一、线程池参数 1、corePoolSize(必填):核心线程数...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作