java多线程入门(五)线程池的使用

简介: java多线程入门(五)线程池的使用

1.为什么用线程池



  • 线程池会维护和创建一些存活的线程,达到开箱即用的效果
  • 对线程的重复利用,减少线程的创建、销毁对系统的开销
  • 有任务执行的时候,可以直接执行,减少系统响应时间
  • 线程池可以有效的管控线程,反例每个请求过来都创建个线程在并发量的大的时候系统可能会挂掉的


2.创建线程池的几种方式



  • //创建一个缓冲池,缓冲池容量大小为Integer.MAX_VALUE,在执行任务为空的时候会释放掉线程的,有新任务的时候需要重新创建线程
  • Executors.newCachedThreadPool();
  • //创建容量为1的缓冲池
  • Executors.newSingleThreadExecutor();
  • //创建固定容量大小的缓冲池 它不会释放工作线程,还会占用一定的系统资源
  • Executors.newFixedThreadPool(int);
  • //创建周期性执行的线程池
  • Executors.newScheduledThreadPool(1);
  • 通过代码可以看到上面的线程创建都是基于ThreadPoolExecutor创建出来的


ThreadPoolExecutor介绍



public ThreadPoolExecutor(int corePoolSize,
                              int maximumPoolSize,
                              long keepAliveTime,
                              TimeUnit unit,
                              BlockingQueue<Runnable> workQueue,
                              ThreadFactory threadFactory,
                              RejectedExecutionHandler handler) 
//调用
executor.execute(Runnable command)
executor.sumbit(Runnable command)
//这里可以有返回值
executor.sumbit(Callable <T> task)
Future<String> future = executor.submit(callable);
System.out.println(future.get())
复制代码


参数介绍


  • corePoolSize 核心线程数定义了最小可以同时运行的线程数量
  • maximumPoolSize 线程池最大线程数,线程池最多可以创建的线程数
  • keepAliveTime 线程没有任务执行时最多保持多久时间会终止
  • unit 时间单位
  • workQueue 一个阻塞队列,用来存储等待执行的任务
  • ArrayBlockingQueue 有界队列
  • LinkedBlockingQueue 无界队列
  • SynchronousQueue 同步队列
  • threadFactory 线程工厂,主要用来创建线程
  • RejectedExecutionHandler 拒绝策略
  • ThreadPoolExecutor.AbortPolicy:丢弃任务并抛出RejectedExecutionException异常。
  • ThreadPoolExecutor.DiscardPolicy:也是丢弃任务,但是不抛出异常。
  • ThreadPoolExecutor.DiscardOldestPolicy:丢弃队列最前面的任务,然后重新尝试执行任务(重复此过程)
  • ThreadPoolExecutor.CallerRunsPolicy:由调用线程处理该任务


执行过程


  • 获取系统CPU个数
  • Runtime.getRuntime().availableProcessors()


网络异常,图片无法展示
|

相关文章
|
6天前
|
安全 Java 数据库
一天十道Java面试题----第四天(线程池复用的原理------>spring事务的实现方式原理以及隔离级别)
这篇文章是关于Java面试题的笔记,涵盖了线程池复用原理、Spring框架基础、AOP和IOC概念、Bean生命周期和作用域、单例Bean的线程安全性、Spring中使用的设计模式、以及Spring事务的实现方式和隔离级别等知识点。
|
3天前
|
设计模式 前端开发 Java
【前端学java】SpringBootWeb极速入门-分层解耦(03)
【8月更文挑战第13天】SpringBootWeb极速入门-分层解耦(03)
8 2
【前端学java】SpringBootWeb极速入门-分层解耦(03)
|
4天前
|
开发框架 前端开发 Java
【前端学java】SpringBootWeb极速入门-实现一个简单的web页面01
【8月更文挑战第12天】SpringBootWeb极速入门-实现一个简单的web页面01
15 3
【前端学java】SpringBootWeb极速入门-实现一个简单的web页面01
|
4天前
|
JSON 前端开发 Java
【前端学java】SpringBootWeb极速入门-请求参数解析(02)
【8月更文挑战第12天】SpringBootWeb极速入门-请求参数解析(02)
10 1
【前端学java】SpringBootWeb极速入门-请求参数解析(02)
|
1天前
|
前端开发 IDE Java
"揭秘前端转Java的秘径:SpringBoot Web极速入门,掌握分层解耦艺术,让你的后端代码飞起来,你敢来挑战吗?"
【8月更文挑战第19天】面向前端开发者介绍Spring Boot后端开发,通过简化Spring应用搭建,快速实现Web应用。本文以创建“Hello World”应用为例,展示项目基本结构与运行方式。进而深入探讨三层架构(Controller、Service、DAO)下的分层解耦概念,通过员工信息管理示例,演示各层如何协作及依赖注入的使用,以此提升代码灵活性与可维护性。
|
1天前
|
Java
多线程线程同步
多线程的锁有几种方式
|
1天前
|
安全 C# 开发者
【C# 多线程编程陷阱揭秘】:小心!那些让你的程序瞬间崩溃的多线程数据同步异常问题,看完这篇你就能轻松应对!
【8月更文挑战第18天】多线程编程对现代软件开发至关重要,特别是在追求高性能和响应性方面。然而,它也带来了数据同步异常等挑战。本文通过一个简单的计数器示例展示了当多个线程无序地访问共享资源时可能出现的问题,并介绍了如何使用 `lock` 语句来确保线程安全。此外,还提到了其他同步工具如 `Monitor` 和 `Semaphore`,帮助开发者实现更高效的数据同步策略,以达到既保证数据一致性又维持良好性能的目标。
6 0
|
3天前
|
算法 安全 Java
深入解析Java多线程:源码级别的分析与实践
深入解析Java多线程:源码级别的分析与实践
|
4天前
|
存储 监控 算法
掌握Java内存管理:从入门到精通
在Java的世界里,内存管理是程序运行的心脏。本文将带你走进Java内存管理的奥秘,从基础概念到高级技巧,一步步揭示如何优化你的Java应用。准备好迎接挑战,让我们共同揭开高效内存使用的面纱!
|
4天前
|
Java UED
基于SpringBoot自定义线程池实现多线程执行方法,以及多线程之间的协调和同步
这篇文章介绍了在SpringBoot项目中如何自定义线程池来实现多线程执行方法,并探讨了多线程之间的协调和同步问题,提供了相关的示例代码。
31 0