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

天津免费做网站天津科技公司网站

天津免费做网站,天津科技公司网站,指数型基金怎么买,怎样做专业网站文章目录 #x1f6f8;前言#x1f339;Executors的三大方法 #x1f354;简述线程池#x1f386;手动创建线程池⭐源码分析✨代码实现#xff0c;手动创建线程池#x1f388;CallerRunsPolicy()#x1f388;AbortPolicy()#x1f388;DiscardPolicy()#x1f388;Dis… 文章目录 前言Executors的三大方法 简述线程池手动创建线程池⭐源码分析✨代码实现手动创建线程池CallerRunsPolicy()AbortPolicy()DiscardPolicy()DiscardOldestPolicy() 前言 Executors的三大方法 Java 中的 Executors 类提供了创建和管理线程池的工厂方法。主要有以下三种常用的静态工厂方法 newFixedThreadPool(int nThreads)固定的线程池大小 创建一个固定大小的线程池其中包含指定数量的线程。如果所有线程都处于活动状态并且任务队列已满那么新任务将在任务队列中等待直到有空闲的线程可用。 newCachedThreadPool()遇强则强遇弱则弱 创建一个可缓存的线程池如果线程池的当前规模超过处理需求时它会回收空闲线程当需求增加时则可以添加新的线程线程池规模不存在限制。 newSingleThreadExecutor() 单个线程 创建一个单线程的线程池该线程池只有一个工作线程它保证所有任务按顺序执行。 这些工厂方法都返回实现了 ExecutorService 接口的 ThreadPoolExecutor 对象这是 Java 线程池的一个具体实现提供了对线程池的操作和控制。通过使用这些工厂方法创建线程池可以方便快捷地满足不同场景下的线程管理需求。 由于使用Executors不安全那么我们需要手动创建一个线程池 简述线程池 线程池是一种用于管理和重用线程的机制它通过预先创建一组线程并将任务提交给这些线程来执行。线程池可以有效地控制并发线程的数量避免了频繁创建和销毁线程的开销提高了系统的性能和资源利用率。 线程池通常由以下组件构成 线程池管理器ThreadPoolExecutor负责创建、管理和调度线程池中的线程。它维护着一个线程池的状态包括线程数量、任务队列、线程工厂等属性。工作线程Worker Thread线程池中的实际执行任务的线程。线程池会创建一定数量的工作线程每个工作线程可以执行多个任务。任务队列Task Queue用于存储待执行的任务。当线程池中的线程空闲时它们会从任务队列中获取任务并执行。线程工厂Thread Factory用于创建新的线程对象。线程池在需要创建新线程时会使用线程工厂创建线程对象。 线程池的主要优点包括 提高系统性能线程池可以控制并发线程的数量避免了过多的线程竞争和频繁的线程创建销毁开销提高了系统的性能。提高资源利用率线程池可以重用线程避免了线程创建和销毁的开销提高了系统的资源利用率。提供线程管理和监控线程池提供了对线程的管理和监控机制可以方便地查看线程池的状态、线程执行情况等信息便于调优和排查问题。 使用线程池时需要根据具体的业务需求和系统资源情况合理配置线程池的大小、任务队列的容量以及其他相关参数避免因线程池过小或过大导致的性能问题。 手动创建线程池 ⭐源码分析 newSingleThreadExecutor的源码 newFixedThreadPool的源码 newCachedThreadPool的源码 其中有个参数长度是Integer,MAX_VALUE长度过大可能会堆积大量的请求对应了上面我们说的不能用Executors而要用ThreadPoolExecutors 我们发现上面三者的源码中都有ThreadPoolExecutor 说明调用线程的本质调用的是ThreadPoolExecutor 下面我们来分析一下ThreadPoolExecutor 下面我们来想象一个场景来更好的理解线程池 比如我们去银行办理业务 银行有5个窗口但是只打开了2个代表核心线程池的大小为2还有3个没有开触发最大并发量的情况下才会打开这3个窗口还有容量为3的候客区阻塞队列 然后有用户去办理业务了假如来了3个用户2个去窗口了还有1个在候客区等待此时又来了3个用户这时候客区的位置不够了阻塞队列满了就要打开那关闭的3个窗口触发最大并发量了 ✨代码实现手动创建线程池 CallerRunsPolicy() package org.Test6;import java.util.concurrent.*;public class Demo01 {public static void main(String[] args) {//自定义线程池ExecutorService threadPool new ThreadPoolExecutor(2,5,3,TimeUnit.SECONDS, //超时等待时间new LinkedBlockingQueue(3),Executors.defaultThreadFactory(),new ThreadPoolExecutor.CallerRunsPolicy());try {for (int i 1; i 10; i) {//使用线程池后使用线程池来创建线程threadPool.execute(()-{System.out.println(Thread.currentThread().getName()ok);});}}catch (Exception e){e.printStackTrace();}finally {//关闭线程池threadPool.shutdown();}} } 代码里面的超时等待时间是什么意思 我们对应上面去银行的场景触发最大并发条件后所有窗口都打开了一段时间后所有用户都离开了过了设定的时间都没有业务那么后面3个窗口就要关闭 AbortPolicy() package org.Test6;import java.util.concurrent.*;public class Demo01 {public static void main(String[] args) {//自定义线程池ExecutorService threadPool new ThreadPoolExecutor(2,5,3,TimeUnit.SECONDS, //超时等待时间new LinkedBlockingQueue(3),Executors.defaultThreadFactory(),new ThreadPoolExecutor.AbortPolicy());try {for (int i 1; i 10; i) {//使用线程池后使用线程池来创建线程threadPool.execute(()-{System.out.println(Thread.currentThread().getName()ok);});}}catch (Exception e){e.printStackTrace();}finally {//关闭线程池threadPool.shutdown();}} } DiscardPolicy() package org.Test6;import java.util.concurrent.*;public class Demo01 {public static void main(String[] args) {//自定义线程池ExecutorService threadPool new ThreadPoolExecutor(2,5,3,TimeUnit.SECONDS, //超时等待时间new LinkedBlockingQueue(3),Executors.defaultThreadFactory(),new ThreadPoolExecutor.DiscardPolicy());try {for (int i 1; i 10; i) {//使用线程池后使用线程池来创建线程threadPool.execute(()-{System.out.println(Thread.currentThread().getName()ok);});}}catch (Exception e){e.printStackTrace();}finally {//关闭线程池threadPool.shutdown();}} } 丢掉任务但是不会抛出异常 DiscardOldestPolicy() package org.Test6;import java.util.concurrent.*;public class Demo01 {public static void main(String[] args) {//自定义线程池ExecutorService threadPool new ThreadPoolExecutor(2,5,3,TimeUnit.SECONDS, //超时等待时间new LinkedBlockingQueue(3),Executors.defaultThreadFactory(),new ThreadPoolExecutor.DiscardOldestPolicy());try {for (int i 1; i 10; i) {//使用线程池后使用线程池来创建线程threadPool.execute(()-{System.out.println(Thread.currentThread().getName()ok);});}}catch (Exception e){e.printStackTrace();}finally {//关闭线程池threadPool.shutdown();}} } 在技术的道路上我们不断探索、不断前行不断面对挑战、不断突破自我。科技的发展改变着世界而我们作为技术人员也在这个过程中书写着自己的篇章。让我们携手并进共同努力开创美好的未来愿我们在科技的征途上不断奋进创造出更加美好、更加智能的明天
http://www.yutouwan.com/news/91712/

相关文章:

  • 建个网站需要服务器吗我想学室内设计怎么学
  • 广州品牌网站设计价格互联网公司网站建设费用
  • 北京网站制作工具wordpress设置假阅读量
  • 网站建设公司成就萝岗区网站建设推广
  • ps手绘网站有哪些长春哪里做网站
  • 怎么给网站做链接有没有好用的网站推荐
  • 免费的网站模板下载wordpress商城
  • 无锡网页建站英文网站制作 官网
  • 郑州网站建设及托管网站支付接口如何做
  • 广州网站建设新锐从事网站建设
  • 新手学做网站用什么软件做网站导航菜单
  • 网站建设的收入来源西安短视频制作公司
  • 建网站的重要性googleseo优化
  • 做网站用什么写电子商务网站的运营一般需要做哪些准备
  • 贵州省建设厅造价通官方网站老师做家教的网站
  • html个人网站模版福州微网站开发
  • 帮别人做数学题赚钱的网站青岛房产网站
  • python工程打包供网站开发调用常德市做公司网站的公司
  • 株洲网站开发公司电话网站seo收录
  • 北京企业网站seo平台做+淘宝客最大的网站是叫什么
  • 深圳房管局官网查询系统惠州优化怎么做seo
  • 网站开发招标文件范本wordpress后台置顶
  • 做网站网站需要多少钱东莞网站建设 石佳
  • 怎么建设自己产品网站加强网站制度建设
  • 狠狠做狠狠干免费网站开发者选项怎么打开
  • 企业网站维护工作计划什么是网络营销网络营销的特点有哪些
  • 合肥市建设工程信息价网站做电商网站有什语言好
  • 网站动态设计效果定制网站和模板网站有何区别
  • 作文网下载山东seo优化
  • 网站运营外包公司2022百度搜索风云榜