线程池

作者: GrovessevorG | 来源:发表于2019-03-28 10:43 被阅读0次

    问:一、线程池的好处

      1、降低我们资源的消耗,因为我们可以重复利用我们已经创建好的线程,降低不断创建和销毁线程所带来的资源消耗。

      2、提高响应速度,我们知道当任务达到一定的数量时,任务不需要等到线程创建就立即执行(因为有创建好的可以循环利用)。

      3、提高线程的可管理性,毕竟线程还是比较稀缺的资源,尤其是手机当中,如果你无限制的创建线程,不仅仅会消耗系统资源,同时还会降低系统的稳定性,使用线程池可以进行统一的分配,可以合理的的利用线程池,也提高了线程池的管理性。

    问:二、线程池的参数

    传递参数讲解

      corePoolSize,:线程池的大小

      maximumPoolSize:最大线程池大小

      keepAliveTime:线程池中超过corePoolSize数目的空闲线程最大存活时间;可以allowCoreThreadTimeOut(true)使得核心线程有效时间

      unit:keepAliveTime时间单位

      workQueue:阻塞任务队列

      threadFactory:新建线程工厂

      RejectedExecutionHandler:当提交任务数超过maxmumPoolSize+workQueue之和时,任务会交给RejectedExecutionHandler来处理(保护策略)

    重点讲解:

      其中比较容易让人误解的是:corePoolSize,maximumPoolSize,workQueue之间关系。

      1.当线程池小于corePoolSize时,新提交任务将创建一个新线程执行任务,即使此时线程池中存在空闲线程。 

      2.当线程池达到corePoolSize时,新提交任务将被放入workQueue中,等待线程池中任务调度执行 

      3.当workQueue已满,且maximumPoolSize>corePoolSize时,新提交任务会创建新线程执行任务 

      4.当提交任务数超过maximumPoolSize时,新提交任务由RejectedExecutionHandler处理 

      5.当线程池中超过corePoolSize线程,空闲时间达到keepAliveTime时,关闭空闲线程 

      6.当设置allowCoreThreadTimeOut(true)时,线程池中corePoolSize线程空闲时间达到keepAliveTime也将关闭

      7.最后调用.execute()提交任务,不过.execute()没有返回值,所以不能判断这个任务是否被线程池执行成功,这是隐患之处

    问:三、线程池的工作流程

      1、首先线程池判断,基本线程池是否已满如果线程池已满,进入下个流程。如果没有满,我们就会创建一个工作(子线程)线程来执行该任务。

      2、如果线程池工作队列满了 如果工作队列满了,进入下一个流程,如果没有满,我们就会将提交的任务存储到该工作队列中,来进行相应的策略处理。 

      3、最后线程池判断整个线程池是否已满。 如果整个线程池已经满了,就会交给我们的RejectdExecutionHandler处理,可以抛出异常也可以忽略这个问题。如果没有满就会创建一个新的工作线程。

    相关文章

      网友评论

          本文标题:线程池

          本文链接:https://www.haomeiwen.com/subject/ngwfbqtx.html