当前位置: 首页 > wzjs >正文

四川网站建设一站式服务商营销组合策略

四川网站建设一站式服务商,营销组合策略,虚拟产品货源网站,js菜鸟教程什么是线程池? 线程池是用来管理和复用线程的⼯具,它可以减少线程的创建和销毁开销。 在 Java 中,ThreadPoolExecutor 是线程池的核⼼实现,它通过核⼼线程数、最⼤线程数、任务队列和拒绝策略来 控制线程的创建和执⾏。 举个栗…

什么是线程池?

线程池是用来管理和复用线程的⼯具,它可以减少线程的创建和销毁开销。

在 Java 中,ThreadPoolExecutor 是线程池的核⼼实现,它通过核⼼线程数、最⼤线程数、任务队列和拒绝策略来 控制线程的创建和执⾏。

举个栗子:就像你开了⼀家餐厅,线程池就相当于固定数量的服务员,顾客(任务)来了就安排空闲的服务员(线 程)处理,避免了频繁招⼈和解雇的成本。

线程池的工作流程

可以简单的总结为:

任务提交 → 核⼼线程执⾏ → 任务队列缓存 → 非核心线程执⾏ → 拒绝策略处理。

第⼀步,线程池通过 submit() 提交任务。

ExecutorService threadPool = Executors.newFixedThreadPool(5);threadPool.submit(() -> {System.out.println(Thread.currentThread().getName() + "\t" + "办理业务");})

第⼆步,线程池会先创建核⼼线程来执⾏任务。

if (workerCountOf(c) < corePoolSize) {if (addWorker(command, true)) {return;}}

第三步,如果核⼼线程都在忙,任务会被放⼊任务队列中。

workQueue.offer(task)

第四步,如果任务队列已满,且当前线程数量⼩于最⼤线程数,线程池会创建新的线程来处理任务。

if (!addWorker(command, false))

第五步,如果线程池中的线程数量已经达到最⼤线程数,且任务队列已满,线程池会执⾏拒绝策略。

handler.rejectedExecution(command, this)

另外一种回答:

第一步,创建线程池;

第二步,调用线程池的execute方法,准备执行任务;

如果正在运行的线程数量小于corePoolSize,那么线程池会创建一个新的线程(核心线程)来执行这个任务;

如果正在运行的线程数量大于等于corePoolSize,那么线程池会将这个任务放入等待队列;

如果等待队列满了 ,并且正在运行的线程数量小于maximumpoolsize,那么线程池会创建一个新的线程(普通线程)来执行这个任务;

如果等待队列满了,并且正在运行的线程数量大于或等于maximumpoolsize,那么线程池会执行拒绝策略。

第三步,线程执⾏完毕后,线程并不会⽴即销毁,⽽是继续保持在池中等待下⼀个任务。

第四步,当线程空闲时间超出指定时间,且当前线程数量⼤于核⼼线程数时,线程会被回收。

线程池的主要参数有哪些?

线程池有 7 个参数,需要重点关注的有核⼼线程数、最⼤线程数、等待队列、拒绝策略。

①、corePoolSize:核⼼线程数,长期存活,执⾏任务的主力。

②、maximumPoolSize:线程池允许的最⼤线程数。

③、workQueue:任务队列,存储等待执⾏的任务。

④、handler:拒绝策略,任务超载时的处理⽅式。也就是线程数达到 maximumPoolSiz,任务队列也满了的时 候,就会触发拒绝策略。

⑤、threadFactory:线程⼯⼚,用于创建线程,可自定义线程名。

⑥、keepAliveTime:非核⼼线程的存活时间,空闲时间超过该值就销毁。

⑦、unit:keepAliveTime 参数的时间单位: 

 简单说一下参数之间的关系:

简单说,任务执行优先使用核心线程,核心线程占用完之后,任务会进入等待队列,队列满了之后,会启用非核心线程执行任务,线程池达到最大线程数量后会触发拒绝策略,非核心线程的空闲时间超过核心时间就会被回收。

核心线程数不够会怎么处理?

当提交的任务数超过了corePoolSize,但是小于最大线程数量,线程池会创建新的线程来处理任务。当提交的任务数超过了最大线程数时,线程池会根据拒绝策略来处理任务。

举个例子说一下这些参数的变化

假设⼀个场景,线程池的配置如下:

corePoolSize = 5maximumPoolSize = 10keepAliveTime = 60秒
workQueue = LinkedBlockingQueue(容量为100)
handler = ThreadPoolExecutor.AbortPolicy()

场景⼀:当系统启动后,有 10 个任务提交到线程池。 前 5 个任务会⽴即执⾏,因为核⼼线程数⾜够容纳它们。 随后的 5 个任务会被放⼊等待队列。

场景⼆:如果此时再有 100 个任务提交到线程池。 ⼯作队列已满,线程池会创建额外的线程来执⾏这些任务,直到线程总数达到 10。 如果任务继续增加,超过了⼯作队列+最⼤线程数的限制,新来的任务会被 AbortPolicy 拒绝,抛出 RejectedExecutionException 异常。

场景三:如果任务突然减少: 核⼼线程会⼀直运⾏,⽽超出核⼼线程数的线程,会在 60 秒后回收。 

线程池的拒绝策略有哪些?

有四种:

AbortPolicy:默认的拒绝策略,会抛 RejectedExecutionException 异常。

CallerRunsPolicy:让提交任务的线程自己来执⾏这个任务,也就是调用 execute 方法的线程。

DiscardOldestPolicy:等待队列会丢弃队列中最老的⼀个任务,也就是队列中等待最久的任务,然后尝试重 新提交被拒绝的任务。

DiscardPolicy:丢弃被拒绝的任务,不做任何处理也不抛出异常。

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

 

 

 

http://www.dtcms.com/wzjs/105078.html

相关文章:

  • 濮阳网站建设熊掌网络杭州seo网
  • 做电视的视频网站b2b免费网站推广平台
  • 广告公司取名大全最新版的烟台seo快速排名
  • 网站建设与文字的工作2023年又封城了
  • 网站空间大小怎么查看营销活动方案模板
  • 小说章节收费网站建设源码网
  • 对企业网站建设的建议短期的技能培训有哪些
  • 淘宝网站做多久黑龙江暴雪预警
  • 在自己的网站里做讲课视频怎么推广游戏代理赚钱
  • 德阳哪里有做网站的网站关键词搜索排名优化
  • 美团网站建设规划书十大it教育培训机构排名
  • 龙门城乡规划建设局网站惠州seo优化服务
  • 网络推广怎么做好引擎优化seo是什么
  • 虎门建设网站免费域名注册官网
  • 潍坊设计网站建设营销平台建设
  • 做go kegg的网站百度公司电话是多少
  • 织梦做中英文网站百度seo优化排名如何
  • 大二学生做网站难吗网站seo源码
  • 常州做网站咨询怎样建网站卖东西
  • 平谷微网站建设软文广告推广
  • 深圳网站建设服零售客户电商网站
  • 郑州电力高等专科学校招生官网seo教学免费课程霸屏
  • 日喀则网站制作电脑系统优化工具
  • 17网站一起做网店可靠吗汕头seo管理
  • 建网站的网站有哪些深圳抖音推广公司
  • centos。wordpress天门seo
  • 网站建设兼职合同模板网络推广中心
  • 公司做宣传网站发票可以抵扣不资源
  • 黄页搜客seo优化的基本流程
  • 朱子网站建设焊工培训