线程池

作者: 徐大哈_401d | 来源:发表于2018-06-13 11:11 被阅读5次

一:线程池的特点

1.复用线程池中的线程,避免线程的重复创建和销毁而造成性能的过度消耗。

2.有效的控制线程池的最大并发数,避免对CPU的资源抢夺而造成阻塞。

3.对线程进行简单的管理,比如定时执行和按一定的时间间隔循环执行。

二:线程池的创建跟销毁

1.execute和submit都是把线程提交到线程池当中,但是execute是没有返回值的void,在exetuor中。submit返回有计算结果的Furture对象,在executeService中。

2.shutdown和shutdownNow是销毁线程池的方法。shutdown()方法只会中断空闲的线程,但是不会影响到已经存入队列的任务,如果需要停止线程池的运行,可以使用awaitTermination()方法.

三:线程池的分类

1.FixedThreadPool

//特点:

//核心线程数和最大线程数相同.

//无超时时间

public static ExecutorService newFixedThreadPool(int nThreads) {

        return new ThreadPoolExecutor(

                nThreads, nThreads,

                0L, TimeUnit.SECONDS,

                new LinkedBlockingQueue()

        );

这是一种数量固定的线程池,当线程处于空闲的时候,并不会被回收,除非线程池被关闭.

当所有的线程都处于活动状态时,新任务都会处于等待状态,直到有线程空闲出来.

2.CacheThreadPool

//无核心线程,并且最大线程数为int的最大值.

//超时时间为60s

//队列为SynchronousQueue同步阻塞队列,队列中没有任何容量.只有在有需求的情况下,队列中才可以试着添加任务.

public static ExecutorService newCacheThreadPool(){

        return  new ThreadPoolExecutor(

                0,Integer.MAX_VALUE,

                60L,TimeUnit.SECONDS,

                new SynchronousQueue()

        );

    }

(1)比较适合执行大量的耗时较少的任务.

(2)当整个线程都处于闲置状态时,线程池中的线程都会超时而被停止,这时候的CacheThreadPool几乎不占任何系统资源的.

3.ScheduledThreadPool


public static ScheduledExecutorService newScheduledThreadPool(int corePoolSzie) {

        return new ScheduledThreadPoolExecutor(corePoolSzie);

    }

//核心线程数是固定的,非核心线程无限大,并且非核心线程数有10s的空闲存活时间    public ScheduledThreadPoolExecutor(int corePoolSize) {

        super(corePoolSize, Integer.MAX_VALUE,

                DEFAULT_KEEPALIVE_MILLIS, MILLISECONDS,

                new DelayedWorkQueue());

    }

它的核心线程数量是固定的,而非核心线程数是没有限制的,并且当非核心线程闲置时会被立即回收.

ScheduThreadPool这类线程池主要用于执行定时任务和具有固定周期的重复任务.

4.SingleThreadExecutor


public static ExecutorService newSingleThreadExecutor() {

        return Executors.newSingleThreadExecutor();

    }

    //特点:    //线程中只有一个核心线程    //并且无超时时间    public static ExecutorService newSingleThreadExecutor() {

        return new FinalizableDelegatedExecutorService

                (new ThreadPoolExecutor(1, 1,

                        0L, TimeUnit.MILLISECONDS,

                        new LinkedBlockingQueue()));

    }

这类线程池内部只有一个核心线程,它确保所有的任务都在同一个线程中按顺序执行.

相关文章

  • java线程池

    线程VS线程池 普通线程使用 创建线程池 执行任务 执行完毕,释放线程对象 线程池 创建线程池 拿线程池线程去执行...

  • java----线程池

    什么是线程池 为什么要使用线程池 线程池的处理逻辑 如何使用线程池 如何合理配置线程池的大小 结语 什么是线程池 ...

  • Java线程池的使用

    线程类型: 固定线程 cached线程 定时线程 固定线程池使用 cache线程池使用 定时调度线程池使用

  • Spring Boot之ThreadPoolTaskExecut

    初始化线程池 corePoolSize 线程池维护线程的最少数量keepAliveSeconds 线程池维护线程...

  • 线程池

    1.线程池简介 1.1 线程池的概念 线程池就是首先创建一些线程,它们的集合称为线程池。使用线程池可以很好地提高性...

  • 多线程juc线程池

    java_basic juc线程池 创建线程池 handler是线程池拒绝策略 排队策略 线程池状态 RUNNIN...

  • ThreadPoolExecutor线程池原理以及源码分析

    线程池流程: 线程池核心类:ThreadPoolExecutor:普通的线程池ScheduledThreadPoo...

  • 线程池

    线程池 [TOC] 线程池概述 什么是线程池 为什么使用线程池 线程池的优势第一:降低资源消耗。通过重复利用已创建...

  • java 线程池使用和详解

    线程池的使用 构造方法 corePoolSize:线程池维护线程的最少数量 maximumPoolSize:线程池...

  • 线程池

    JDK线程池 为什么要用线程池 线程池为什么这么设计 线程池原理 核心线程是否能被回收 如何回收空闲线程 Tomc...

网友评论

    本文标题:线程池

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