创建线程池的七中方式

一、newSingleThreadExecutor()

它的特点在于工作线程数目被限制为1,操作一个无界的工作队列,所以它包正了所有任务都是被顺序执行,最多会有一个任务处于活动状态,并且不允许使用者改动线程池实例,因此可以避免其改变线程池数目。

二、newFixedThreadPool(int nThread)

它是一种用来处理大量短时间工作任务的线程池,具有几个鲜明的特点
①它会试图缓存线程并重用,当无缓存线程可以用时,它会创建新的工作线程。
②如果线程的限制时间超过60秒,则会终止并移出缓存。
③长时间闲置时,这种线程池不会消耗什么资源。
它内部使用的是ScychronousQueue作为工作队列

三、newCachedThreadPool()

它使用来创建指定数目的线程。其背后使用的是无界的工作队列,任何时候最多有指定数目的工作线程是活动的。这意味着如果任务数量超过了指定的活动队列数目,将在工作队列总等待空闲线程的出现;如果有工作线程退出将会有新的工作线程被创建,由来补足指定的线程数目

四、newSingleThreadScheduledExecutor()

创建单线程池,返回ScheduledExectorService,可以进行定时或周期性的工作调度

五、newScheduledThreadPool()

和newSingleThreadScheduledExecutor()类似,创建的是一个ScheduledExectorService,可以进行定时或者周期性调度,区别在于单一工作线程还是多个工作线程

六、newWorkStealPool(int parallelism)

Java8才加入这个创建方法,其内部会构建ForkJoinPool,利用Work-Stealing算法,并行地处理任务,不保证任务的处理顺序

七、ThreadExecutorPool()

它是最原始的线程池创建,上面1-3创建方式,都是对ThreadExecutorPool()的封装

猜你喜欢

转载自blog.csdn.net/qq_42697271/article/details/113726770
今日推荐