当前位置: 首页 > news >正文

java 线程池

线程池 是 一个 容器,其中管理着多个线程(预先创建并维护一定数量的线程),当有一个任务a需要一个线程去完成时,从容器(线程池)中获取一个线程A去执行任务a,当线程A完成任务a后,线程A又回到容器中。

(公司招聘10个员工(线程),他们在各种的工位上等待分配任务,

当有一个任务出现时,选取一名员工去执行任务,当他将任务执行完毕后又回到自己的工位等待下一个任务)

而不是

(公司有任务需要做,于是招聘一个员工去完成该任务,当任务完成后,该员工离开公司,下次再有任务时又招聘新的员工)

节约了线程创建和销毁的开销。

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class ThreadPoolExample {public static void main(String[] args) {// 创建一个固定大小为 5 的线程池ExecutorService executor = Executors.newFixedThreadPool(5);// 提交任务给线程池执行for (int i = 0; i < 10; i++) {executor.execute(new Task(i));}// 关闭线程池executor.shutdown();}
}class Task implements Runnable {private int taskId;public Task(int id) {taskId = id;}@Overridepublic void run() {System.out.println("Task #" + taskId + " is running in Thread #" + Thread.currentThread().getId());}
}

首先创建了一个固定大小为 5 的线程池。然后使用一个循环提交了 10 个任务给线程池执行,每个任务都是一个实现了Runnable接口的对象。当任务被线程池执行时,它们会输出自己的编号和线程的编号。最后我们通过调用 shutdown() 方法关闭线程池。

Executors是一个工厂类,可以通过它来创建各种类型的线程池

  • newFixedThreadPool(int nThreads):创建一个固定大小的线程池,池中有固定数量的线程;
  • newSingleThreadExecutor():创建只有一个线程的线程池;
  • newCachedThreadPool():创建一个可根据需要创建新线程的线程池等。

ExecutorService是一个接口,它扩展了Executor接口,具有更完整的线程池控制方法,并且支持提交可返回结果的任务(Callable)。通过使用ExecutorService,我们可以方便地提交任务、关闭线程池、管理任务执行流程并获取任务执行结果。

在实际应用中,我们通常通过Executors创建一个线程池,然后将任务通过ExecutorService提交给线程池执行。

http://www.lryc.cn/news/65948.html

相关文章:

  • 音频焦点使用及原理
  • PyQt5桌面应用开发(8):从QInputDialog转进到函数参数传递
  • 2.0 Vue框架设计的核心要素
  • “智慧赋能 强链塑链”——精细化工行业仓储物流数字化转型探讨
  • 用DG备库做的rman备份恢复一个数据库
  • JAVA中的IO操作有哪些?
  • 10:00面试,10:04就出来了 ,问的实在是太...
  • wangzherongyao PMO
  • Dart语法上
  • SignOff Criteria——POCV(Parametric OCV) introduction
  • Android 内存分析(java/native heap内存、虚拟内存、处理器内存 )
  • 产品思维与工程师思维
  • Android---启动速度优化
  • 使用 Mercury 直接从 Jupyter 构建 Web 程序
  • Python基础(二)
  • 第41讲:Python循环语句中的break-else语法结构
  • 双系统-真机安装ubuntu
  • Android实现向facebook回复消息代码
  • IDEA小技巧-Git的回滚强推代码找回
  • 即时通讯为什么不采用UDP的连接方式呢
  • 二叉树(纲领篇)
  • day41—选择题
  • Vue3 watch 监听对象数组中对象的特定属性
  • 请求策略库alova小记
  • [C++]string的使用
  • Kali Linux 操作系统安装详细步骤——基于 VMware 虚拟机
  • R语言APSIM模型应用及批量模拟实践技术
  • 破解马赛克有多「容易」?
  • 【.NET基础加强第八课--委托】
  • jetcache:阿里这款多级缓存框架一定要掌握