JUC并发编程-第二天:线程池相关

2024-06-15 23:20

本文主要是介绍JUC并发编程-第二天:线程池相关,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

线程池相关

  • 线程池
    • 内置线程池的使用
    • 线程池的关闭
    • excute方法和submit方法的区别

线程池

线程池就是一个可以复用线程的技术

  public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue<Runnable> workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler){return null;}

*[ ] 各个参数的含义

  • corePoolSize:线程池的核心线程数(正式员工)
  • maximumPoolSize:指定的最大线程数量(核心线程数和临时线程数之和)
    最大员工总数:正式员工+外包员工
  • keepAliveTime:临时线程存活时间(外包合同期限)
  • unit:临时线程存活时间单位
  • workQueue:任务队列(项目)
  • threadFactory:线程工厂(招人的hr)
  • handler:线程池拒绝策略

内置线程池的使用

内置线程池使用Executors工具类去创建线程池
在这里插入图片描述

public class ThreadPool {public static void main(String[] args) {//创建固定大小的线程池ExecutorService executorService = Executors.newFixedThreadPool(5);//创建单线程线程池ExecutorService threadExecutor = Executors.newSingleThreadExecutor();//创建动态线程线程池ExecutorService service = Executors.newCachedThreadPool();}
}

线程池的关闭

使用shutdown()或者shutdownNow()

  • shutdown():线程执行完后关闭;
  • shutdownNow():立即关闭,不管线程是否执行完毕;
    关闭线程池,如果不关闭,线程池中的线程会一直占用系统资源,会导致内存泄漏,主线程一直不会退出

excute方法和submit方法的区别

excute方法用来执行runable任务对象。而submit方法用来执行未来任务对象

  • 以计算1-100的任务为例
  • excuter方法
public class RunableExcuteTask implements Runnable{int goal;public RunableExcuteTask(int goal) {this.goal = goal;}@Overridepublic void run() {int sum=0;for (int i = 1; i <=goal ; i++) {sum=sum+i;}System.out.println("1-"+goal+"的和是:"+sum);}
}

测试

public class ThreadPool {public static void main(String[] args) {Runnable task=new RunableExcuteTask(100);ExecutorService threadPool = Executors.newFixedThreadPool(5);threadPool.execute(task);threadPool.shutdown();}
}
  • submit方法
public class CallableExcuteTask implements Callable<Integer> {int goal;public CallableExcuteTask(int goal) {this.goal = goal;}@Overridepublic Integer call() throws Exception {int sum=0;for (int i = 1; i <= goal; i++) {sum=sum+i;}return sum;}
}

测试

public class ThreadPool {public static void main(String[] args) throws ExecutionException, InterruptedException {ExecutorService threadPool = Executors.newFixedThreadPool(5);CallableExcuteTask excuteTask = new CallableExcuteTask(100);Future<Integer> future = threadPool.submit(excuteTask);Integer integer = future.get();System.out.println(integer);}
}
  • 在处理异常方面

excute会在子线程中抛出异常,在主线程中捕捉不到;
submit不会立马抛出异常,而是会将异常暂时储存起来,等我们调用future.get()方法的时候才会抛出,并且可以在主线程中抛出。处理异常更方便

这篇关于JUC并发编程-第二天:线程池相关的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1064873

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

MySQL中处理数据的并发一致性的实现示例

《MySQL中处理数据的并发一致性的实现示例》在MySQL中处理数据的并发一致性是确保多个用户或应用程序同时访问和修改数据库时,不会导致数据冲突、数据丢失或数据不一致,MySQL通过事务和锁机制来管理... 目录一、事务(Transactions)1. 事务控制语句二、锁(Locks)1. 锁类型2. 锁粒

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer