【线程池】ThreadPoolExecutor的使用示例

文章目录

    • 通过ThreadPoolExecutor创建线程池。
    • 线程的处理结果如何获取?

通过ThreadPoolExecutor创建线程池。

ThreadPoolExecutor构造方法参数:

  • int corePoolSize //核心线程数量
  • int maximumPoolSize//最大线程数
  • long keepAliveTime//当线程数大于核心线程数时,多余空闲线程存活的最长时间
  • TimeUnit unit//keepAliveTime的时间单位
  • BlockingQueue<Runnable> workQueue//任务队列,用来储存等待执行任务的队列
  • ThreadFactory threadFactory//用来创建线程的线程工厂,一般默认
  • RejectedExecutionHandler handler//拒绝策略,当提交的任务过多而不能及时处理时所执行的处理策略

演示使用ThreadPoolExecutor执行任务


import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;public class TestThreadPool {public static void main(String[] args) {// 创建一个线程池ThreadPoolExecutor executor = new ThreadPoolExecutor(5,  // 核心线程数5,  // 最大线程数2,  // 当线程数大于核心线程数时,多余的空闲线程存活的最长时间TimeUnit.SECONDS,  // 存活时间单位new LinkedBlockingQueue<>(10)  // 任务队列,用来储存等待执行任务的队列);// 提交任务给线程池for (int i = 0; i < 10; i++) {final int taskId = i;executor.submit(new Runnable() {@Overridepublic void run() {System.out.println("Task " + taskId + " is being executed by " + Thread.currentThread().getName());try {Thread.sleep(1000); // 模拟任务执行时间} catch (InterruptedException e) {e.printStackTrace();}System.out.println("Task " + taskId + " is completed");}});}// 关闭线程池executor.shutdown();}
}

在这个示例中,使用 ThreadPoolExecutor 创建了一个线程池,提交了 10 个任务给线程池,线程池会根据核心线程数和任务队列的情况来分配线程执行任务。任务执行完毕后,线程池会复用线程,如果线程池中的线程数量超过核心线程数,空闲线程在空闲时间后可能会被回收。

最后,调用 shutdown 方法关闭线程池,等待所有任务完成后关闭。

代码运行:
在这里插入图片描述

上述代码中的,提交任务给线程池时所调用的submit也可更改为execute方法。

execute 适用于只关心任务的执行,不需要获取返回值或处理异常的情况;submit 适用于需要获取任务的执行结果或捕获异常的情况。

ThreadPoolExecutor类:
在这里插入图片描述
AbstractExecutorService抽象类(ThreadPoolExecutor的父类):
在这里插入图片描述

线程的处理结果如何获取?

代码:

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;public class TestThreadPool2 {public static void main(String[] args) {// 创建一个线程池ThreadPoolExecutor executor = new ThreadPoolExecutor(5,  // 核心线程数5,  // 最大线程数2,  // 当线程数大于核心线程数时,多余的空闲线程存活的最长时间TimeUnit.SECONDS,  // 存活时间单位new LinkedBlockingQueue<>(10)  // 任务队列,用来储存等待执行任务的队列);List<Future<Integer>> futureList = new ArrayList<>();// 提交任务给线程池for (int i = 0; i < 6; i++) {final int taskId = i;Future<Integer> future = executor.submit(new Callable<Integer>() {@Overridepublic Integer call() throws Exception {System.out.println("Task " + taskId + " is being executed by " + Thread.currentThread().getName());Thread.sleep(2000); // 模拟任务执行时间return taskId * 2;}});futureList.add(future);}System.out.println("———————flag1———————————");// 获取线程的返回值for (Future<Integer> future : futureList) {try {int result = future.get();//get方法会阻塞,直到任务完成并返回结果System.out.println("Task result: " + result);} catch (InterruptedException | ExecutionException e) {e.printStackTrace();}}System.out.println("———————flag2———————————");// 关闭线程池executor.shutdown();}
}

该示例代码创建了一个自定义的 ThreadPoolExecutor,并提交了一系列的 Callable 任务。每个任务都会返回一个整数值。我们将每个任务的 Future 对象存储在一个列表中,然后使用 get 方法获取每个任务的返回值。注意,get 方法会阻塞,直到任务完成并返回结果。

输出:
在这里插入图片描述

参考:

  • https://pdai.tech/md/java/thread/java-thread-x-juc-executor-ThreadPoolExecutor.html#threadpoolexecutor%E6%BA%90%E7%A0%81%E8%AF%A6%E8%A7%A3
  • https://javaguide.cn/java/concurrent/java-concurrent-questions-03.html#%E7%BA%BF%E7%A8%8B%E6%B1%A0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/83967.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ChatGPT在高等教育中的应用利弊探讨

​人工智能在教育领域的应用日益广泛。2022年11月OpenAI开发的聊天机器人ChatGPT在全球范围内流传开来&#xff0c;其中用户数量最多的国家是美国(15.22%)。由于ChatGPT应用广泛&#xff0c;具有类似人类回答问题的能力&#xff0c;它正在成为许多学生和教育工作者的可信赖伙伴…

指针-C语言(初阶)

目录 一、什么是指针 二、指针和指针类型 2.1 指针-整数 2.2 指针的解引用 三、野指针 3.1 野指针形成原因 3.2 如何规避野指针 四、指针运算 4.1 指针-整数 4.2 指针-指针 4.3 指针的关系运算 五、指针和数组 六、二级指针 七、指针数组 一、什么是指针 指针是内存中一个…

Little Kernel代码学习笔记

目录 虚拟地址转换为物理地址内核启动Multiboot头部结构启动时的寄存器状态real_start段选择子初始化BSS段 页表转换设置CR4、CR3、EFER寄存器设置页表映射 初始化IDT&#xff0c;执行lk_main 虚拟地址转换为物理地址 // start.S#define PHYS_LOAD_ADDRESS (MEMBASE KERNEL_L…

RabbitMQ---订阅模型-Direct

1、 订阅模型-Direct • 有选择性的接收消息 • 在订阅模式中&#xff0c;生产者发布消息&#xff0c;所有消费者都可以获取所有消息。 • 在路由模式中&#xff0c;我们将添加一个功能 - 我们将只能订阅一部分消息。 例如&#xff0c;我们只能将重要的错误消息引导到日志文件…

华为云开发工具CodeArts IDE for C/C++ 开发使用指南

简介 CodeArts IDE是一个集成开发环境&#xff08;IDE&#xff09;&#xff0c;它提供了开发语言和调试服务。本文主要介绍CodeArts IDE for C/C的基本功能。 1.下载安装 CodeArts IDE for C/C 已开放公测&#xff0c;下载获取免费体验 2.新建C/C工程 CodeArts IDE for C/…

多维时序 | Matlab实现LSTM-Adaboost和LSTM多变量时间序列预测对比

多维时序 | Matlab实现LSTM-Adaboost和LSTM多变量时间序列预测对比 目录 多维时序 | Matlab实现LSTM-Adaboost和LSTM多变量时间序列预测对比预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 多维时序 | Matlab实现LSTM-Adaboost和LSTM多变量时间序列预测对比 模型…

C++:命名空间,缺省参数,函数重载,引用,内联函数

个人主页 &#xff1a; 个人主页 个人专栏 &#xff1a; 《数据结构》 《C语言》《C》 文章目录 前言一、命名空间命名空间的定义命名空间的使用 二、缺省参数缺省参数概念缺省参数分类 三、函数重载函数重载的概念 四、引用引用的概念引用特性引用的使用场景引用与指针的区别 …

stm32之15.超声波与灯光功能一起实现(进阶)

主函数代码修改 --------------------- 源码 int main(void) {uint32_t t0;uint32_t distance;NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);led_init();key_init();/* 初始化串口1波特率为115200bps&#xff0c;若发送/接收数据有乱码&#xff0c;请检查PLL */usart1_ini…

亚马逊云科技 云技能孵化营 初识机器学习

目录 前言 一、课程介绍 二、什么是机器学习 三、机器学习算法进阶过程 四、亚马逊云科技能给我们什么 总结 前言 近期参加了“亚马逊云科技 云技能孵化营”&#xff0c;该孵化营的亚马逊云科技培训与认证团队为开发者准备了云从业者的精要知识及入门课程&#xff0c;帮助…

MybatisPlus(1)

前言&#x1f36d; ❤️❤️❤️SSM专栏更新中&#xff0c;各位大佬觉得写得不错&#xff0c;支持一下&#xff0c;感谢了&#xff01;❤️❤️❤️ Spring Spring MVC MyBatis_冷兮雪的博客-CSDN博客 MyBatis-Plus&#xff08;简称MP&#xff09;是一个 Mybatis 的增强工具&…

【PHP】数据类型运算符位运算

文章目录 数据类型简单&#xff08;基本&#xff09;数据类型&#xff1a;4个小类复合数据类型&#xff1a;2个小类特殊数据类型&#xff1a;2个小类类型转换类型判断整数类型浮点类型布尔类型 运算符赋值运算符算术运算符比较运算符逻辑运算符连接运算符错误抑制符三目运算符自…

[PyTorch][chapter 51][Auto-Encoder -1]

目录&#xff1a; 简介 损失函数 自动编码器的类型 一 AutoEncoder 简介&#xff1a; 自动编码器是一种神经网络&#xff0c;用于无监督学习任务.(没有标签或标记数据), 例如降维,特征提取和数据压缩. 主要任务&#xff1a; 1&#xff1a; 输入数据 …