`

Java线程池

 
阅读更多

线程池的有点
1.降低资源消耗,通过重复利用已创建的线程降低线程创建和销毁造成的消耗。
2.提高响应速度,任务可以不需要等线程创建就能立即执行。
3.提高线程可管理性,防止无限制创建导致的消耗系统资源、降低系统稳定性。使用线程池可以进行统一的分配、调优和监控。
4.使用线程池可以有效控制最大并发线程数,提高资源利用率,避免过多资源竞争,避免阻塞。
5.线程池可以提供定时执行、单线程执行、并发控制等,操作线程方便。
6.new Thread不能重复使用,new 相当于在内存中单独开辟一个内存让线程运行,需要释放线程和新建线程,性能差。使用线程池,可以减少对象的创建、消亡的开销。

 

线程池简介

Java中,线程池的概念是Executor这个接口,具体实现为ThreadPoolExecutor类。对线程池的配置,就是对ThreadPoolExecutor构造函数的参数配置。
ThreadPoolExecutor提供了四个构造函数:

 ThreadPoolExecutor策略:

1.线程数量未达到corePoolSize,新建一个线程(核心线程)执行任务
2.线程数量达到corePoolSize,则任务加入列等待。
3.队列已满,新建线程(非核心线程)执行任务。
4.队列已满,总线程数又达到maximumPoolSize,抛出异常。

 

ThreadPoolExecutor的参数和方法

corePoolSize:核心线程数量。当线程数少于corePoolSize的时候,直接创建新的线程,尽管其他的线程是空闲的。当线程池中的线程数目达到corePoolSize后,会把到达的任务放到缓存队列中。
maximunPoolSize:线程池最大线程数。线程数少于线程最大数目且大于核心线程数目的时候,只有当阻塞队列满了才创建新线程。当线程数量大于最大线程数目且阻塞队列满了是会执行一些策略来影响该线程。
workQueue:阻塞队列,存储等待执行的任务。当所有核心线程都执行时,新增加任务会被添加到这个队列中等待处理,如果队列满了,则新建非核心线程执行。
常用workQueue类型:
SynchronousQueue:接收任务后直接给线程处理,如果线程都在工作,就创建新线程。为了不保证达到最大线程数,maximumPoolSize一般指定无限大。
LinkedBlockingQueue:当线程数小于核心线程数则新建线程,如果等于核心线程数,则进入等待队列,由于队列没有最大限制,即所有超过线程线程数的线程都被添加到该队列中,导致maximumPoolSize设定失效。
ArrayBlockingQueue:可限定队列长度,如果没有达到核心线程数,则新建核心线程,如果达到了,则入队等候,如果队列已满,则新建线程(非核心线程),如果达到最大限制数,并且队列也满了,则发生错误。
DelayQueue:队列元素必须实现Delayed接口,队列接收任务时,首先先入队,达到指定延时时间才会执行。

keepAliveTime:非核心线程没有任务执行最多保持多久时间终止。
allowCoreThreadTimeOut=true:上面的时间作用于核心线程。
unit:keepAliveTime的时间单位
threadFactory:线程工厂,用来创建线程。使用默认工厂创建线程时,线程具有相同的优先级。
handler:拒绝策略。
execute();添加任务。
submit();提交任务,返回execute+Future。
invokeAll();方法接收一个list<Callable>,当全部任务都执行完成后返回List<Future<T>>,并且能保证请求和返回值的顺序是一致的。
shutdown();关闭线程池,等待任务都执行完。
shutdownNow();关闭线程池,不等待任务执行完。
getTaskCount();线程池已执行和未执行的任务总数。
getCompletedTaskCount();已完成的任务数量。
getPoolSize();当前线程数量。
getActiveCount();正在执行任务的线程数量。

 

Executor线程池创建的四种线程
1. newFixedThreadPool:创建的是定长的线程池,可以控制线程最大并发数,超出的线程会等待,使用无界队列,核心线程数和最大线程数一样,当线程没有任务时立刻销毁。
2. newSingleThreadExecutor:创建的是单线程化的线程池,只会用唯一一个线程执行,可以指定是否按照先入先出,还是优先级来执行。是无界队列,核心线程数和最大线程数都是1个。
3. newCachedThreadPool:设定一个可缓存的线程池,当线程池长度超过处理的需要,可以灵活回收空闲线程,如果没有可回收才创建新线程。没有核心线程数,当线程没任务60s后就会回收空闲线程,有界队列。
4. newScheduledThreadPool:支持线程定时操作和周期性操作。


常用四种线程池方法

CachedThreadPool()
可缓存线程池:
1.线程数无限制
2.有空闲则复用空闲线程,若无空闲线程则新建线程。
3.一定程序减少频繁创建/销毁线程,减少系统开销。
创建方法:ExccutorServicecachedThreadPool=Executors.newCachedThreadPool();

FixedThreadPool()
定长线程池:
1.可控制线程最大并发数。
2.超出的线程会在队列中等待。
创建方法:
ExecutorService fixedThreadPool=Executors.newFixedThreadPool(int maximumPoolSize);

ScheduledThreadPool()
定长线程池
执行定时及周期性任务执行。
ExecutorServicescheduledThreadPool=Executors.newScheduledThreadPool(int corePoolSize);

SingleThreadExecutor()
单线程化的线程池
1.仅有一个线程执行任务
2.所有任务按照指定顺序执行,遵循队列的入队出队规则。
创建方法:
ExecutorServicesingleThreadPool=Executor.newSingleThreadPool();

 

使用例子

ExecutorService fixedThreadPool = Executors.newFixedThreadPool(15);
fixedThreadPool.submit(() -> {
    System.out.println("test");               
}));
ThreadPoolExecutor threadPoolExecutor=new ThreadPoolExecutor(
    8,
    maxPoolSize,
    keepAlive,
    TimeUnit.SECONDS,
    new SynchronousQueue<>(),
    new ThreadFactoryBuilder().setNamePrefix("text-").build());
threadPoolExecutor.invokeAll(new LinkedList<Callable<Object>>(), 3, TimeUnit.MINUTES);

 

分享到:
评论

相关推荐

    Java 线程池框架

    Java线程池框架是Java并发处理的核心工具,它允许开发者高效地管理多个并发任务,避免了频繁创建和销毁线程的开销。线程池通过维护一组可重用的线程来提高系统的性能和响应性。本文将深入探讨Java线程池的结构、常见...

    谈谈Java 线程池

    Java线程池是一种高效利用系统资源、管理和控制并发的重要工具。在Java中,线程池的概念借鉴了数据库连接池的思想,旨在通过复用已存在的线程来减少创建和销毁线程的开销,从而提高程序的运行效率。线程池不仅能够...

    java线程池封装j

    Java线程池是一种高效管理线程的技术,它允许开发者预定义一组线程,根据任务的需要灵活调度,而不是每次需要执行任务时都创建新的线程。这种设计模式大大提高了系统的性能,减少了系统资源的消耗,特别是在高并发...

    JAVA线程池原理实例详解

    JAVA线程池原理实例详解 JAVA线程池是java中的一种高效的线程管理机制,它可以控制线程的创建、销毁和复用,从而提高系统的性能和可靠性。下面我们将详细介绍JAVA线程池的原理、创建、使用方法及相关注意事项。 一...

    JAVA线程池例子

    Java线程池是一种高效管理线程资源的技术,它允许开发者创建一组可重用的工作线程,从而避免频繁地创建和销毁线程带来的性能开销。线程池在Java中主要通过`java.util.concurrent`包中的`ExecutorService`接口及其...

    java线程池使用后到底要关闭吗

    java线程池使用后到底要关闭吗 java线程池是一种高效的并发编程技术,可以帮助开发者更好地管理线程资源,提高系统的性能和可靠性。然而,在使用java线程池时,一个常见的问题是:使用完线程池后到底要不要关闭?...

    Java 线程池.pptx

    讲述了java线程池的优点,参数,6种线程池的使用场景,线程池用到的handler,线程任务的提交方式等等。

    java线程池知识.ppt

    java线程池知识、

    Java 线程池.docx

    Java线程池是一种高效管理线程资源的工具,它的出现是为了应对多线程编程中频繁创建和销毁线程带来的性能开销以及资源消耗。在Java中,通过使用线程池,我们可以预先创建一定数量的线程,这些线程在空闲时可以被复用...

    java 线程池

    Java线程池是一种高效管理并发任务执行的机制,它通过维护一组可重用的线程来减少创建和销毁线程的开销。线程池在Java中由`java.util.concurrent`包下的`ExecutorService`接口及其实现类,尤其是`ThreadPoolExecutor...

    四种Java线程池用法解析

    Java线程池是Java并发编程中的重要组成部分,主要用于管理和调度线程资源,以提高系统的效率和稳定性。Java通过`java.util.concurrent.ExecutorService`接口和`java.util.concurrent.Executors`工厂类提供了四种...

    java线程池实现批量下载文件

    Java线程池实现批量下载文件 Java线程池实现批量下载文件是指使用Java语言和线程池机制来实现批量下载文件的功能。这种方法可以大幅提高下载速度和效率,特别是当需要下载大量文件时。下面将对Java线程池实现批量...

    Java线程池使用说明

    Java线程池是Java并发编程中的重要组件,它能够有效地管理和复用线程,从而提高程序的执行效率和降低资源消耗。在JDK 1.5版本之前,Java对线程池的支持非常有限,而在JDK 1.5之后,加入了java.util.concurrent包,...

    Java线程池技术详解

    【Java线程池技术详解】 线程池是Java并发编程中的一个重要概念,它是一种线程使用模式,旨在优化线程的管理和使用,提高系统资源的利用率。线程池的引入是为了应对频繁创建和销毁线程所带来的性能开销,因为创建和...

    搞懂Java线程池

    搞懂Java线程池 Java线程池是Java编程中非常重要的知识点,多线程并发算是Java进阶的知识,用好多线程不容易有太多的坑。在Java中,创建线程是一个“重”操作,需要调用操作系统内核API,然后操作系统再为线程分配...

    深入java线程池的使用详解

    在Java 5.0之前启动一个任务是通过调用Thread类的start()方法来实现的,任务的提于交和执行是同时进行的,如果你想对任务的执行进行调度或是控制 同时执行的线程数量就需要额外编写代码来完成。5.0里提供了一个新的...

    Java线程池.docx

    Java线程池 Java线程池是Java语言中的一种高级多线程处理机制,用于避免重复创建和销毁线程而导致额外的性能开销。Java线程池功能可以实现线程的复用,提高了系统的性能和效率。 Java线程池分类 Java线程池可以...

    Java线程池的拒绝策略实现详解

    Java线程池的拒绝策略实现详解 Java线程池的拒绝策略是指当线程池中的线程数量达到最大值时,如何处理新的任务提交的策略。这个策略是由RejectedExecutionHandler接口定义的,提供了四种默认的拒绝策略:...

    自定义实现Java线程池

    ### 自定义实现Java线程池 #### 一、概述 在深入探讨自定义Java线程池之前,我们先简要回顾一下线程池的基本概念及其重要性。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动...

    java线程池详解文档

    ### Java线程池详解 #### 一、线程池概念 线程池是一种多线程处理形式,它能够高效地管理多个线程的生命周期,并在处理任务时避免频繁创建和销毁线程所带来的开销。线程池允许我们将任务(通常是实现了`Runnable`...

Global site tag (gtag.js) - Google Analytics