java线程池应用案例

news/2023/9/28 18:24:59

java线程池应用案例

  • 一、线程池知识
    • 二、线程池的创建
    • 1、测试线程
    • 2、普通测试案例
    • 3、newSingleThreadExecutor
    • 4、newFixedThreadPool
    • 5、 newCachedThreadPool
    • 6、newScheduledThreadPool(情况一)
    • 7、newScheduledThreadPool(情况二)
    • 7、newScheduledThreadPool(情况三)


一、线程池知识

根据系统的环境情况,可以自动或手动设置线程数量,达到运行的最佳效果;少了浪费了系统资源,多了造成系统拥挤效率不高。用线程池控制线程数量,其他线程排队等候。一个任务执行完毕,再从队列的中取最前面的任务开始执行。若队列中没有等待进程,线程池的这一资源处于等待。当一个新任务需要运行时,如果线程池中有等待的工作线程,就可以开始运行了;否则进入等待队列。

  • 减少了创建和销毁线程的次数,每个工作线程都可以被重复利用,可执行多个任务。
  • 可以根据系统的承受能力,调整线程池中工作线线程的数目,防止因线程过多消耗内存,也避免了因线程过少,浪费系统资源。

二、线程池的创建

1、测试线程

public class MyThread extends Thread {private int i;public MyThread(int in) {this.i = in;}@Overridepublic void run() {try {sleep(500);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(currentThread().getName() + "正在打印:" + i);}
}

2、普通测试案例

    void contextLoad6() {for (int i = 0; i < 10; i++) {MyThread myThread = new MyThread(i);myThread.run();}}

在这里插入图片描述

3、newSingleThreadExecutor

说明:初始化只有一个线程的线程池,内部使用LinkedBlockingQueue作为阻塞队列。
特点:相当于单线程串行执行所有任务如果该线程异常结束,会重新创建一个新的线程继续执行任务,唯一的线程可以保证所提交任务的顺序执行

    void contextLoad7() {ExecutorService executorService = Executors.newSingleThreadExecutor();for (int i = 0; i < 10; i++) {executorService.execute(new MyThread(i));}executorService.shutdown();try {Thread.sleep(10000);} catch (InterruptedException e) {e.printStackTrace();}}

在这里插入图片描述

4、newFixedThreadPool

说明:初始化一个指定线程数的线程池,其中corePoolSize == maxiPoolSize,使用LinkedBlockingQuene作为阻塞队列
特点:每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小。线程池的大小一旦达到最大值就会保持不变,即使当线程池没有可执行任务时,也不会释放线程。如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。

    void contextLoad8() {ExecutorService executorService = Executors.newFixedThreadPool(5);for (int i = 0; i < 10; i++) {executorService.execute(new MyThread(i));}executorService.shutdown();try {Thread.sleep(10000);} catch (InterruptedException e) {e.printStackTrace();}}

在这里插入图片描述

5、 newCachedThreadPool

说明:初始化一个可以缓存线程的线程池,此线程池不会对线程池大小做限制,线程池大小完全依赖于操作系统(或者说JVM)能够创建的最大线程大小。线程池的线程数可达到Integer.MAX_VALUE,即2147483647,内部使用SynchronousQueue作为阻塞队列;
特点:在没有任务执行时,当线程的空闲时间超过keepAliveTime,默认为60s,会自动释放线程资源;当提交新任务时,如果没有空闲线程,则创建新线程执行任务,会导致一定的系统开销;
因此,使用时要注意控制并发的任务数,防止因创建大量的线程导致而降低性能。

    void contextLoad9() {ExecutorService executorService = Executors.newCachedThreadPool();for (int i = 0; i < 10; i++) {executorService.execute(new MyThread(i));}executorService.shutdown();try {Thread.sleep(10000);} catch (InterruptedException e) {e.printStackTrace();}}

在这里插入图片描述

6、newScheduledThreadPool(情况一)

特定:初始化的线程池可以在指定的时间内周期性的执行所提交的任务,在实际的业务场景中可以使用该线程池定期的同步数据。
总结:除了newScheduledThreadPool的内部实现特殊一点之外,其它线程池内部都是基于ThreadPoolExecutor类(Executor的子类)实现的。

public class MyThread2 extends Thread {private int i;public MyThread2(int in) {this.i = in;}@Overridepublic void run() {while (true) {try {//每两秒执行一次sleep(2000);} catch (InterruptedException E) {E.printStackTrace();}SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");Date date = new Date();System.out.println(currentThread().getName() + "打印编号:" + i + "======>" + sdf.format(date));//答应当前时间}}}
    void contextLoad10() {ScheduledThreadPoolExecutor atpe = new ScheduledThreadPoolExecutor(5);//设置线程个数for (int i = 0; i < 5; i++) {atpe.execute(new MyThread2(i));//普通的提交方式,只提交一次,执行结束,线程不会退出。}try {Thread.sleep(10000);} catch (InterruptedException e) {e.printStackTrace();}}

在这里插入图片描述

7、newScheduledThreadPool(情况二)

程序正常结束,且线程3被重复利用,并没达到线程池的最大容量4。
我们可以这样认为,newScheduledThreadPool这线程池可以使只执行一遍的线程以一定速率循环执行,但是如果以execute方式提交线程则不会重复执行。

public class MyThread3 extends Thread {private int i;public MyThread3(int in) {this.i = in;}@Overridepublic void run() {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");Date date = new Date();System.out.println(currentThread().getName() + "打印编号:" + i + "======>" + sdf.format(date));//答应当前时间}
}
    void contextLoad11() {ScheduledThreadPoolExecutor atpe = new ScheduledThreadPoolExecutor(4);//设置线程个数for (int i = 0; i < 5; i++) {atpe.execute(new MyThread3(i));//普通的提交方式,只提交一次,执行结束,线程不会退出。}try {Thread.sleep(10000);} catch (InterruptedException e) {e.printStackTrace();}}

在这里插入图片描述

7、newScheduledThreadPool(情况三)

我们可以发现线程2实现了重复利用,虽然创建的线程是一次执行,但却实现了重复执行的效果,这就是该线程池最大的特点。

    void contextLoad12() {ScheduledThreadPoolExecutor atpe = new ScheduledThreadPoolExecutor(4);//设置线程个数for (int i = 0; i < 5; i++) {//参数2:initialDelay表示首次执行任务的延迟时间,参数3:period表示每次执行任务的间隔时间,参数4:TimeUnit.MILLISECONDS执行的时间间隔数值单位atpe.scheduleAtFixedRate(new MyThread3(i),1000,2000, TimeUnit.MILLISECONDS);//以固定频率重复执行线程}try {Thread.sleep(10000);} catch (InterruptedException e) {e.printStackTrace();}}

在这里插入图片描述


https://dhexx.cn/news/show-18198.html

相关文章

利用hue调度shell脚本和hive脚本-Demo演示

在HDFS上创建一个shell脚本程序文件 在HDFS上创建一个hive sql脚本程序文件 如以下文件 打开工作流调度页面。 调用hive脚本 调用shell脚本

MyBatis-Plus学习LambdaQueryWrapper

MyBatis-Plus学习LambdaQueryWrapper一、代码以及配置1、数据库2、依赖3、配置文件4、配置类5、实体类6、持久层7、测试方法8、结果二、其他1、::作用2、LambdaQueryWrapper对象使用一、代码以及配置 1、数据库 CREATE TABLE med_user (id int(11) NOT NULL AUTO_INCREMENT,u…

XML解析普通方法与Jsoup工具

文章目录一、普通方法1、工具代码2、测试代码3、效果4、xml测试文本二、使用Jsoup1、依赖2、测试代码3、效果一、普通方法 1、工具代码 public class DOMUtil {public void DomXml(String sb) {//创建一个DocumentBuilderFactory的对象DocumentBuilderFactory dbf DocumentB…

利用Hue配置定时调度任务

利用Hue配置定时调度任务 在hue中&#xff0c;也可以针对workflow配置定时调度任务&#xff0c;具体操作如下&#xff1a; 一定要注意时区的问题&#xff0c;否则调度就出错了。保存之后就可以提交定时任务。 点击进去&#xff0c;可以看到定时任务的详细信息。

Windows下面安装easy_install报UnicodeDecodeError: 'ascii' codec can't decode byte解决方法

在运行python ez_setup.py install后&#xff0c; 发现是在下载并解压setuptools-2.1&#xff0c;并运行setup.py时出现如下错误&#xff1a; 提示D:\Python27\lib\mimetypes.py编码问题&#xff0c;由于Python2.5 初始化后会删除 sys.setdefaultencoding 这个方法&#xff0c;…

MySQL索引最左匹配原则

MySQL索引最左匹配原则一、案例一1、表与索引创建2、查询语句举例3、那么究竟用到了哪些索引呢&#xff1f;4、原因二、案例二1、表与索引创建2、查询语句举例3、原因4、最左匹配原则三、案例三1、表与索引创建2、查询语句举例3、原因以及补充资料一、案例一 1、表与索引创建 …

Impala概述,特点,缺点,架构说明

1、概述 Impala是Cloudera公司推出&#xff0c;提供对HDFS、Hbase数据的高性能、低延迟的交互式SQL查询功能。基于Hive使用内存计算&#xff0c;兼顾数据仓库、具有实时、批处理、多并发等优点impala使用hive的元数据, 完全在内存中计算是CDH平台首选的PB级大数据实时查询分析引…

如何在页面中(html 等)设置IE浏览器的文档模式

最近在使用一个开源框架&#xff0c;发现该框架能跨浏览器和版本&#xff0c;但唯独在IE下的Quirks Model下表现不太好。一开始想着如何自己去完善在该模式下的问题&#xff0c;后来一想为何不找到一种方法&#xff0c;在代码里面设置好让页面在IE浏览器下面不呈现Quirks Model…

整数的除法产生一个浮点数

整数的除法产生一个浮点数一、整数的除法产生一个浮点数1、代码2、结果3、解析二、其他一、整数的除法产生一个浮点数 1、代码 Testvoid contextLoad17() {int a 1;int b 2;float f1 a / b;float f2 (float) a / b;float f3 (float) (a / b * 1.0);float f4 (float) (1.…

Impala安装方式

Impala安装方式有两种 1 通过Cloudera Manager(CDH方式安装)&#xff0c;推荐用这个&#xff0c;方便 2 手动安装&#xff0c;此方式级其复杂 下面通过Cloudera Manager的方式安装Impala 在主页中点击添加服务 选择Impala服务 进行角色分配 注意&#xff1a;最好将StateS…