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

面试高频知识点:2线程 2.1.5如何自定义实现一个线程池

在Java中,线程池是一种用于管理线程的机制,它可以有效地管理多个线程并且可以重复使用它们,从而减少了线程创建和销毁的开销,提高了线程的利用率。本文将介绍如何自定义实现一个简单的线程池,并提供相应的Java代码示例。

线程池的基本原理

自定义一个简单的线程池需要考虑以下几个关键组件:

  1. 任务队列(Task Queue):用于存储待执行的任务。

  2. 线程池管理器(ThreadPool Manager):负责管理线程池,包括创建、销毁线程等操作。

  3. 工作线程(Worker Thread):实际执行任务的线程。

基本的工作流程如下:

  1. 当有任务需要执行时,将任务添加到任务队列中。

  2. 线程池管理器不断从任务队列中取出任务,并分配给空闲的工作线程执行。

  3. 执行完任务的工作线程将结果返回,并继续等待下一个任务。

  4. 当任务队列为空且没有新的任务添加时,线程池管理器会关闭线程池。

实现一个简单的线程池

下面是一个简单的Java实现:

import java.util.LinkedList;
import java.util.List;public class CustomThreadPool {private final int maxThreads;private final List<WorkerThread> threads;private final LinkedList<Runnable> taskQueue;public CustomThreadPool(int maxThreads) {this.maxThreads = maxThreads;threads = new LinkedList<>();taskQueue = new LinkedList<>();for (int i = 0; i < maxThreads; i++) {WorkerThread worker = new WorkerThread();threads.add(worker);worker.start();}}public synchronized void submit(Runnable task) {taskQueue.add(task);notify();}public synchronized void shutdown() {for (WorkerThread worker : threads) {worker.stopThread();}}private class WorkerThread extends Thread {private boolean running = true;@Overridepublic void run() {while (running) {Runnable task;synchronized (CustomThreadPool.this) {while (taskQueue.isEmpty()) {try {CustomThreadPool.this.wait();} catch (InterruptedException e) {e.printStackTrace();}}task = taskQueue.poll();}try {task.run();} catch (RuntimeException e) {e.printStackTrace();}}}public void stopThread() {running = false;}}
}// 示例任务
class ExampleTask implements Runnable {private final int taskId;public ExampleTask(int taskId) {this.taskId = taskId;}@Overridepublic void run() {System.out.println("Task " + taskId + " is being executed by Thread: " + Thread.currentThread().getName());}
}// 示例用法
class Main {public static void main(String[] args) {CustomThreadPool threadPool = new CustomThreadPool(3);for (int i = 1; i <= 5; i++) {Runnable task = new ExampleTask(i);threadPool.submit(task);}threadPool.shutdown();}
}

示例解析

  • CustomThreadPool 类实现了一个简单的线程池,其中包含了最大线程数、工作线程列表和任务队列等成员变量。

  • submit 方法用于向线程池提交任务,并唤醒等待中的工作线程。

  • shutdown 方法用于关闭线程池,通过停止所有工作线程的运行来实现。

  • WorkerThread 类继承自 Thread,表示线程池中的工作线程,其 run 方法循环执行任务队列中的任务。

  • ExampleTask 类是一个示例任务,其中包含了任务的具体执行逻辑。

  • 在示例中,通过创建线程池并提交任务,可以看到任务在多个工作线程间被并发执行。

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

相关文章:

  • 【stm32】hal库学习笔记-ADC模数转换(超详细)
  • 蓝桥杯基础知识6 pair
  • 后端返回给前端的数据格式有哪些?
  • Transformer的PyTorch实现之若干问题探讨(一)
  • 系统参数SystemParameters.MinimumHorizontalDragDistance
  • 平屋顶安装光伏需要注意哪些事项?
  • 《Git 简易速速上手小册》第7章:处理大型项目(2024 最新版)
  • 从0开始学Docker ---Docker安装教程
  • 嵌入式学习之Linux入门篇笔记——15,Linux编写第一个自己的命令
  • 【C语言】SYSCALL_DEFINE3(socket, int, family, int, type, int, protocol)
  • C++实现鼠标点击和获取鼠标位置(编译环境visual studio 2022)
  • Matplotlib绘制炫酷散点图:从二维到三维,再到散点图矩阵的完整指南与实战【第58篇—python:Matplotlib绘制炫酷散点图】
  • Docker-Learn(一)使用Dockerfile创建Docker镜像
  • 问题:银行账号建立以后,一般需要维护哪些设置,不包括() #学习方法#经验分享
  • 教授LLM思考和行动:ReAct提示词工程
  • FPGA_工程_按键控制的基于Rom数码管显示
  • WordPress Plugin HTML5 Video Player SQL注入漏洞复现(CVE-2024-1061)
  • 【Kotlin】Kotlin基本数据类型
  • UDP端口探活的那些细节
  • 拦截器配置,FeignClient根据业务规则实现微服务动态路由
  • 预测模型:MATLAB线性回归
  • 【人工智能】神奇的Embedding:文本变向量,大语言模型智慧密码解析(10)
  • Redis + Lua 实现分布式限流器
  • ruoyi若依框架SpringSecurity实现分析
  • Habitat环境学习四:Habitat-sim基础用于导航——使用导航网格NavMesh
  • python学习笔记 -- 字符串
  • 2024年GPT如何发展?
  • 从REPR设计模式看 .NET的新生代类库FastEndpoints的威力
  • 前端入门:(五)JavaScript 续
  • 研究多态恶意软件,探讨网络安全与AI