java线程池超详细解析

news2024/9/20 15:36:00

java线程池超详细解析

  • 一、线程池主要核心原理
  • 二、线程池代码实现
  • 三、自定义线程池
    • 1、自定义线程池原理
    • 2、自定义线程池参数
    • 3、自定义线程池任务拒绝策略
    • 3、代码实现
  • 四、线程池多大合适呢?

一、线程池主要核心原理

  • 创建一个池子,池子中是空的
  • 提交任务时,池子会创建新的线程对象,任务执行完毕,线程归还给池子下回再次提交任务时,不需要创建新的线程,直接复用已有的线程即可
  • 但是如果提交任务时,池子中没有空闲线程,也无法创建新的线程,任务就会排队等待

二、线程池代码实现

Executors:线程池的工具类,通过调用方法返回不同类型的线程池对象

  • public static ExecutorService newCachedThreadPool(); 创建一个没有上限的线程池
  • public static ExecutorService newFixedThreadPool(int nThreads); 创建有上限的线程池

具体实现步骤
1、创建线程池
2、提交任务
3、所有的任务全部执行完毕,关闭线程池

执行任务MyRunnable类

package com.hidata.devops.paas.demo;

/**
 * @Description :
 * @Date: 2023-10-11 09:41
 */
public class MyRunnable implements Runnable {
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()  );
    }
}

测试类


import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * @Description :
 * @Date: 2023-10-11 09:42
 */
public class TestDemo {
    public static void main(String[] args) {
    	//创建线程池对象
        ExecutorService executorService = Executors.newFixedThreadPool(3);
        
		//提交任务
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        executorService.submit(new MyRunnable());
        
		//关闭线程池(一般不会关闭)
        executorService.shutdown();
    }
}

运行结果

pool-1-thread-1
pool-1-thread-3
pool-1-thread-2
pool-1-thread-1
pool-1-thread-2
pool-1-thread-3
pool-1-thread-2
pool-1-thread-1

Process finished with exit code 0

总结

  • 上述代码中,我们创建的线程池,设置的最大线程数为3,当连续提交了8个任务,可以看到打印的结果,只有三个线程在轮换着执行任务,所以当任务数超过最大线程数时,线程池不会创建新的线程,而是等线程池中有空闲的线程时,会复用该空闲线程,继续执行任务,再次强调一遍:不会创建新线程,因为最大线程数为3
  • 实际开发中,线程池一般不会关闭哦

三、自定义线程池

通过Executors工具类调用方法,创建线程池,不够灵活,因为很多的线程池参数都没有办法自定义。所以我们需要自定义线程池。

1、自定义线程池原理

1、创建一个空的池子
2、有任务提交时,线程池会创建线程去执行任务,执行完毕归还线程

不断地提交任务,会有以下三个临界点:
1、当核心线程满时,再提交任务就会排队
2、当核心线程满,队伍满时,会创建临时线程
3、当核心线程满,队伍满,临时线程满时,会触发任务拒绝策略

2、自定义线程池参数

在这里插入图片描述

3、自定义线程池任务拒绝策略

在这里插入图片描述

3、代码实现

package com.hidata.devops.paas.demo;

/**
 * @Description :
 * @Date: 2023-10-11 09:41
 */
public class MyRunnable implements Runnable {
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()  );
    }
}

package com.hidata.devops.paas.demo;

import java.util.concurrent.*;

/**
 * @Description :
 * @Date: 2023-10-11 09:42
 */
public class TestDemo {
    public static void main(String[] args) {
        ThreadPoolExecutor executor = new ThreadPoolExecutor(
                3,//核心线程数量,不能小于0
                6,//最大线程数,不能小于0,最大数量>=核心线程数量
                60,//空闲线程最大存活时间
                TimeUnit.SECONDS,//时间单位
                new ArrayBlockingQueue<>(3),//任务队列
                Executors.defaultThreadFactory(),//创建线程工厂
                new ThreadPoolExecutor.AbortPolicy()//任务拒绝策略
        );
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());
        executor.submit(new MyRunnable());

        executor.shutdown();
    }
}

运行结果

pool-1-thread-2
pool-1-thread-4
pool-1-thread-3
pool-1-thread-3
pool-1-thread-1
pool-1-thread-4
pool-1-thread-2
pool-1-thread-5

Process finished with exit code 0

四、线程池多大合适呢?

线程池大小不能随便写的,要根据你项目的类型,一般分为两种类型的项目:

  • CPU密集型项目:一般是你项目中的计算比较多,但是读取数据库或者读取本地文件操作比较少
  • I/O密集型项目:读取数据库操作或者读取文件操作比较多

针对这两种类型的项目,是有一个公式的,先看一下这个复杂的公式:
在这里插入图片描述
我们发现公式里面出现了多个关键字:最大并行数,那怎么获取操作系统的最大并行数呢?

java底层虚拟机已经提供了获取操作系统最大并行数的方法了:

int count = Runtime.getRuntime().availableProcessors();
System.out.println(count);

也可以打开你电脑的任务管理器,其中逻辑处理器就是最大并行数
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SAP/BW 开发人员安装Eclipse详细过程和踩的坑

之前一直用的HANA STUDIO做BW开发&#xff0c;但是一直各种BUG,就想换成Eclipse&#xff0c;CSDN有几篇写的安装过程&#xff0c;但还是踩了点小坑&#xff0c;记下来当自己笔记&#xff0c;以后再按得时候看一眼。 1.安装的思路 其实没什么思路&#xff0c;就很简单&#xf…

【java学习】包package和引用import(22)

文章目录 1. 为什么需要package包2. JDK中主要的包介绍 1. 为什么需要package包 在java中包的概念就是和文件夹的概念类似&#xff0c;同样&#xff0c;包的存在也是为了解决以上的问题&#xff08;文件太乱不好管理和同名文件冲突&#xff09;          package语句作…

多线程代码中,如何查看各个线程的状态(JAVA)

首先我们先编写一个简单的多线程代码&#xff1a; class MyThread extends Thread{Overridepublic void run() {while (true) {System.out.println("创建的一个新线程");//让循环慢一点try {Thread.sleep(1000);} catch (InterruptedException e) {throw new Runtim…

萝卜刀玩具上架亚马逊CPC认证测试标准

含铅或含铅涂料儿童产品的要求 分阶段限制儿童产品所有部件的铅含量&#xff0c;要求在3年内将产品任何可接触部件的铅含量限制从不超过重量的600ppm&#xff08;0.06%&#xff09;降至不超过重量的100ppm&#xff08;0.01%&#xff09;。 铅含量限值&#xff08;总铅含量占重…

基于DeOldify的给黑白照片、视频上色

老照片常常因为当时的技术限制而只有黑白版本。然而现代的 AI 技术&#xff0c;如 DeOldify&#xff0c;可以让这些照片重现色彩。 本教程将详细介绍如何使用 DeOldify 来给老照片上色。 文章目录 准备工作执行代码图片上色视频上色 总结 准备工作 这里用 git clone 命令克隆…

opencv python 深度学习垃圾图像分类系统 计算机竞赛

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; opencv python 深度学习垃圾分类系统 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;3分工作量&#xff1a;3分创新点&#xff1a;4分 这是一个较为新颖的竞…

17、vivado打开保存的仿真文件

1、保存 仿真完成后直接点击保存&#xff0c;输入wcfg文件名称即可。 2、打开 打开原来保存的波形文件&#xff0c;需分两步走。 首先打开wdb文件&#xff0c;Flow&#xff0c;Open Static simulation&#xff1b; 之后再打开原来保存的wcfg文件&#xff0c; File -> Si…

一款新的webshell管理工具

Alien 项目简介 语言 C# .NET Framework V4.8 功能 File Manager &#xff08;可显示图片&#xff0c; 可SearchFile&#xff09; 虚拟终端 数据库 注册表 监控 截图 系统信息 项目描述 一句话木马 一句话木马是在渗透测试中用来控制服务器的工具 强大之处在于木…

(2023,LLM,扩散,标记对齐,两阶段训练)MiniGPT-5:通过生成式 Voken 进行交错视觉和语言生成

MiniGPT-5: Interleaved Vision-and-Language Generation via Generative Vokens 公众号&#xff1a;EDPJ&#xff08;添加 VX&#xff1a;CV_EDPJ 或直接进 Q 交流群&#xff1a;922230617 获取资料&#xff09; 目录 0. 摘要 1. 简介 2. 相关工作 3. 方法 3.1 多模态…

山海鲸汽车需求调研系统:智慧决策的关键一步

随着社会的发展和科技的进步&#xff0c;汽车行业也迎来了新的挑战和机遇。如何更好地满足用户需求、提高产品竞争力成为了汽车制造商们关注的焦点。在这个背景下&#xff0c;山海鲸汽车需求调研互动系统应运而生&#xff0c;为汽车行业赋予了智慧决策的力量。 智慧决策的核心&…

冠军代言:引领市场潮流的无敌利器!

在当今竞争激烈的商业舞台上&#xff0c;冠军代言已经成为企业吸引更多消费者并提高销售额的无可比拟的利器。这种独特的市场营销策略通过邀请知名运动员、明星或其他广受欢迎的人士代言企业的产品或服务&#xff0c;不仅在短时间内提高了品牌知名度&#xff0c;还能够在消费者…

【转存】异或运算的妙用

概述 异或运算 通过对两个相同长度的二进制数进行逐位比较&#xff0c;若对应位的值不同&#xff0c;结果为 1, 否则结果为 0, Go 语言中使用的运算符号为 ^。 下面举几个简单的小例子: 0 ^ 0 00 ^ 1 11 ^ 0 11 ^ 1 0图片来源: https://www.build-electronic-circuits.c…

Jpg格式如何转成gif格式动图?简单一招搞定gif制作

平时我们看到的使用的gif动图一般是由静态图片合成或是从视频中截取这两种方法制作的。当我们想要将一段视频制作成gif动画却不知从何下手的时候应该怎么办呢&#xff1f;这时候&#xff0c;只需要使用一个在线gif动态图片制作&#xff08;https://www.gif.cn/&#xff09;网站…

时间范围配置(昨天,今天,本周,本月,本季度,本年)

ranges:{ ‘昨天’: [ moment(moment().subtract(1, ‘days’).format(‘YYYY-MM-DD 00:00:00’)) ,moment(moment().subtract(1, ‘days’).format(‘YYYY-MM-DD 23:59:59’))], ‘今天’: [ moment(moment().format(‘YYYY-MM-DD 00:00:00’)),moment( moment().format(‘YYY…

Colab matplotlib画图如何显示中文字体【图例坐标轴均可显示中文】

Colab notebook用matplotlib画图中文出现方块&#xff1a; 如何解决这个问题呢&#xff1f; 运行wget -O simhei.ttf "https://www.wfonts.com/download/data/2014/06/01/simhei/chinese.simhei.ttf"&#xff0c;安装中文字体&#xff0c;这里装得是SimHei&#xf…

pdf文件过大如何减小?快来试试这个方法

在传送pdf文档的时候&#xff0c;如果内容太多&#xff0c;就会导致文件过大不方法发送&#xff0c;所以需要先把pdf压缩&#xff08;pdf压缩 PDF文件压缩 pdf在线压缩工具-压缩图&#xff09;一下&#xff0c;但是下载安装又耽误时间&#xff0c;这里推荐使用pdf在线压缩的方法…

vite vue3 pwa 更新提醒

效果 vite-plugin-pwa插件启用pwa后默认会在后台自动更新应用&#xff0c;并在关闭所有已开启的页面并重新打开后激活 通过此方法可以以消息方式提醒用户手动刷新激活更新应用 方法 已经使用vite-plugin-pwa插件启用pwa 修改vite.config.ts export default defineConfig(…

缓存的力量:提升API性能和可扩展性

缓存是将频繁访问的数据或资源存储在临时存储位置(例如内存或磁盘)的过程&#xff0c;以提高检索速度并减少重复处理的需要。 缓存的好处 提高性能&#xff1a;缓存消除了每次从原始源检索数据的需要&#xff0c;从而提高了响应时间并减少了延迟。减少服务器负载&#xff1a;通…

Maven系列第4篇:仓库详解

maven系列目标&#xff1a;从入门开始开始掌握一个高级开发所需要的maven技能。 这是maven系列第4篇。 整个maven系列的内容前后是有依赖的&#xff0c;如果之前没有接触过maven&#xff0c;建议从第一篇看起&#xff0c;本文尾部有maven完整系列的连接。 环境 maven3.6.1 …

Wifi列表扫描和Wifi链接

上面的截图&#xff0c;就是本文要介绍的主要功能。 1.准备工作&#xff0c;声明权限&#xff1a; <uses-permission android:name"android.permission.CHANGE_WIFI_STATE" /><uses-permission android:name"android.permission.ACCESS_WIFI_STATE&quo…