返回顶部
首页 > 资讯 > 精选 >Java中线程池的使用场景有哪些
  • 686
分享到

Java中线程池的使用场景有哪些

2023-06-16 18:06:52 686人浏览 八月长安
摘要

今天就跟大家聊聊有关Java中线程池的使用场景有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 一、如下方式存在的问题new Thread() {&

今天就跟大家聊聊有关Java中线程池的使用场景有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

 一、如下方式存在的问题

new Thread() {     @Override     public void run() {         // 业务逻辑     } }.start();

首先频繁的创建、销毁对象是一个很消耗性能的事情;2、如果用户量比较大,导致占用过多的资源,可能会导致我们的服务由于资源不足而宕机;3、综上所述,在实际的开发中,这种操作其实是不可取的一种方式。

二、使用线程池有什么优点

线程池中线程的使用率提升,减少对象的创建、销毁;2、线程池可以控制线程数,有效的提升服务器的使用资源,避免由于资源不足而发生宕机等问题;

三、线程池的四种使用方式

1、newCachedThreadPool

创建一个线程池,如果线程池中的线程数量过大,它可以有效的回收多余的线程,如果线程数不足,那么它可以创建新的线程。

public static void method() throws Exception {      ExecutorService executor = Executors.newCachedThreadPool();      for (int i = 0; i < 5; i++) {          final int index = i;          Thread.sleep(1000);          executor.execute(new Runnable() {             @Override             public void run() {                 System.out.println(Thread.currentThread().getName() + "  " + index);             }         });     } }

执行结果

Java中线程池的使用场景有哪些

通过分析我看可以看到,至始至终都由一个线程执行,实现了线程的复用,并没有创建多余的线程。如果当我们的业务需要一定的时间进行处理,那么将会出现什么结果。我们来模拟一下。

Java中线程池的使用场景有哪些

可以明显的看出,现在就需要几条线程来交替执行。

不足:这种方式虽然可以根据业务场景自动的扩展线程数来处理我们的业务,但是最多需要多少个线程同时处理缺是我们无法控制的;

优点:如果当第二个任务开始,第一个任务已经执行结束,那么第二个任务会复用第一个任务创建的线程,并不会重新创建新的线程,提高了线程的复用率;

2、newFixedThreadPool

这种方式可以指定线程池中的线程数。举个栗子,如果一间澡堂子最大只能容纳20个人同时洗澡,那么后面来的人只能在外面排队等待。如果硬往里冲,那么只会出现一种情景,摩擦摩擦...

首先测试一下最大容量为一个线程,那么会不会是我们预测的结果。

public static void method_01() throws InterruptedException {      ExecutorService executor = Executors.newFixedThreadPool(1);      for (int i = 0; i < 10; i++) {          Thread.sleep(1000);         final int index = i;          executor.execute(() -> {             try {                 Thread.sleep(2 * 1000);             } catch (InterruptedException e) {                 e.printStackTrace();             }             System.out.println(Thread.currentThread().getName() + "  " + index);         });     }     executor.shutdown(); }

执行结果

Java中线程池的使用场景有哪些

我们改为3条线程再来看下结果

Java中线程池的使用场景有哪些

优点:两个结果综合说明,newFixedThreadPool的线程数是可以进行控制的,因此我们可以通过控制最大线程来使我们的服务器打到最大的使用率,同事又可以保证及时流量突然增大也不会占用服务器过多的资源。

3、newScheduledThreadPool

该线程池支持定时,以及周期性的任务执行,我们可以延迟任务的执行时间,也可以设置一个周期性的时间让任务重复执行。 该线程池中有以下两种延迟的方法。

  • scheduleAtFixedRate

测试一

public static void method_02() {     ScheduledExecutorService executor = Executors.newScheduledThreadPool(5);      executor.scheduleAtFixedRate(new Runnable() {         @Override         public void run() {             long start = new Date().getTime();             System.out.println("scheduleAtFixedRate 开始执行时间:" +                     DateFORMat.getTimeInstance().format(new Date()));             try {                 Thread.sleep(5000);             } catch (InterruptedException e) {                 e.printStackTrace();             }             long end = new Date().getTime();             System.out.println("scheduleAtFixedRate 执行花费时间=" + (end - start) / 1000 + "m");             System.out.println("scheduleAtFixedRate 执行完成时间:" + DateFormat.getTimeInstance().format(new Date()));             System.out.println("======================================");         }     }, 1, 5, TimeUnit.SECONDS); }

执行结果

Java中线程池的使用场景有哪些

测试二

Java中线程池的使用场景有哪些

总结:以上两种方式不同的地方是任务的执行时间,如果间隔时间大于任务的执行时间,任务不受执行时间的影响。如果间隔时间小于任务的执行时间,那么任务执行结束之后,会立马执行,至此间隔时间就会被打乱。

  • scheduleWithFixedDelay

测试一

public static void method_03() {     ScheduledExecutorService executor = Executors.newScheduledThreadPool(2);      executor.scheduleWithFixedDelay(new Runnable() {         @Override         public void run() {             long start = new Date().getTime();             System.out.println("scheduleWithFixedDelay 开始执行时间:" +                     DateFormat.getTimeInstance().format(new Date()));             try {                 Thread.sleep(1000);             } catch (InterruptedException e) {                 e.printStackTrace();             }             long end = new Date().getTime();             System.out.println("scheduleWithFixedDelay执行花费时间=" + (end - start) / 1000 + "m");             System.out.println("scheduleWithFixedDelay执行完成时间:"                     + DateFormat.getTimeInstance().format(new Date()));             System.out.println("======================================");         }     }, 1, 2, TimeUnit.SECONDS); }

执行结果

Java中线程池的使用场景有哪些

测试二

public static void method_03() {     ScheduledExecutorService executor = Executors.newScheduledThreadPool(2);      executor.scheduleWithFixedDelay(new Runnable() {         @Override         public void run() {             long start = new Date().getTime();             System.out.println("scheduleWithFixedDelay 开始执行时间:" +                     DateFormat.getTimeInstance().format(new Date()));             try {                 Thread.sleep(5000);             } catch (InterruptedException e) {                 e.printStackTrace();             }             long end = new Date().getTime();             System.out.println("scheduleWithFixedDelay执行花费时间=" + (end - start) / 1000 + "m");             System.out.println("scheduleWithFixedDelay执行完成时间:"                     + DateFormat.getTimeInstance().format(new Date()));             System.out.println("======================================");         }     }, 1, 2, TimeUnit.SECONDS); }

执行结果

Java中线程池的使用场景有哪些

总结:同样的,跟scheduleWithFixedDelay测试方法一样,可以测出scheduleWithFixedDelay的间隔时间不会受任务执行时间长短的影响。

4、newSingleThreadExecutor

这是一个单线程池,至始至终都由一个线程来执行。

public static void method_04() {      ExecutorService executor = Executors.newSingleThreadExecutor();      for (int i = 0; i < 5; i++) {         final int index = i;         executor.execute(() -> {             try {                 Thread.sleep(2 * 1000);             } catch (InterruptedException e) {                 e.printStackTrace();             }             System.out.println(Thread.currentThread().getName() + "   " + index);         });     }     executor.shutdown(); }

执行结果

Java中线程池的使用场景有哪些

四、线程池的作用

线程池的作用主要是为了提升系统的性能以及使用率。文章刚开始就提到,如果我们使用最简单的方式创建线程,如果用户量比较大,那么就会产生很多创建和销毁线程的动作,这会导致服务器在创建和销毁线程上消耗的性能可能要比处理实际业务花费的时间和性能更多。线程池就是为了解决这种这种问题而出现的。

同样思想的设计还有很多,比如数据库连接池,由于频繁的连接数据库,然而创建连接是一个很消耗性能的事情,所有数据库连接池就出现了。

看完上述内容,你们对Java中线程池的使用场景有哪些有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网精选频道,感谢大家的支持。

--结束END--

本文标题: Java中线程池的使用场景有哪些

本文链接: https://lsjlt.com/news/284794.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java中线程池的使用场景有哪些
    今天就跟大家聊聊有关Java中线程池的使用场景有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 一、如下方式存在的问题new Thread() {&...
    99+
    2023-06-16
  • java多线程有哪些使用场景
    这期内容当中小编将会给大家带来有关java多线程有哪些使用场景,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java有哪些集合类Java中的集合主要分为四类:1、List列表:有序的,可重复的;2、Que...
    99+
    2023-06-14
  • java多线程的使用场景有哪些
    Java多线程的使用场景有很多,以下是几个常见的场景:1. 并发处理:当需要同时处理多个任务时,可以使用多线程来提高处理效率。例如,...
    99+
    2023-08-15
    java
  • java多线程应用场景有哪些
    Java多线程的应用场景有以下几种:1. 任务并行:当一个任务可以被分解为多个独立的子任务,并且这些子任务可以并行执行时,可以使用多...
    99+
    2023-09-13
    java
  • java中ThreadLocal的使用场景有哪些
    今天就跟大家聊聊有关java中ThreadLocal的使用场景有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。常用的java框架有哪些1.SpringMVC,Spring Web...
    99+
    2023-06-14
  • java中SPI的使用场景有哪些
    这期内容当中小编将会给大家带来有关java中SPI的使用场景有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现...
    99+
    2023-06-14
  • Java中WeakHashMap的使用场景有哪些
    Java中WeakHashMap是一种可以自动删除不再使用的键值对的Map实现,它的使用场景包括:1. 缓存:WeakHashMap...
    99+
    2023-09-29
    Java
  • python中下划线的使用场景有哪些
    python中下划线的使用场景有哪些?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、_用于临时变量单下划线一般用于表示临时变量,在REPL、for循环和元组拆包等场景中比...
    99+
    2023-06-15
  • java线程池使用的方法有哪些
    Java线程池使用的方法有以下几种:1. Executors类的静态方法:- newFixedThreadPool(int nThr...
    99+
    2023-08-20
    java
  • Java线程池的使用方法有哪些
    本文小编为大家详细介绍“Java线程池的使用方法有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java线程池的使用方法有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。线程池的创建⽅法总共有 7 种,但...
    99+
    2023-07-05
  • Java的线程池有哪些
    这篇文章主要讲解了“Java的线程池有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java的线程池有哪些”吧!线程池简介 线程池的概念:线程池就是首先创建一些线程,它们的集合...
    99+
    2023-06-02
  • java线程池有哪些
    java的线程池有:1.newCachedThreadPool,线程数量不定的线程池;2.newFixedThreadPool,指定工作线程数量的线程池;3.newScheduledThreadPool,核心线程数量是固定的线程池;4.ne...
    99+
    2024-04-02
  • Java中Executors有哪些线程池
    本篇文章给大家分享的是有关Java中Executors有哪些线程池,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。java基本数据类型有哪些Java的基本数据类型分为:1、整数类...
    99+
    2023-06-14
  • C++多线程的应用场景有哪些
    C++多线程的应用场景包括但不限于以下几个方面:1. 并发处理:多线程可以用于同时执行多个任务,提高程序的并发处理能力。例如,可以用...
    99+
    2023-09-21
    C++
  • android多线程的应用场景有哪些
    Android多线程的应用场景主要有以下几个:1. 后台任务处理:Android应用通常需要在后台执行一些耗时的任务,如网络请求、数...
    99+
    2023-09-12
    android
  • Python多进程与多线程的使用场景有哪些
    这篇文章主要介绍Python多进程与多线程的使用场景有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言Python多进程适用的场景:计算密集型(CPU密集型)任务Python多线程适用的场景:IO密集型任务计算...
    99+
    2023-06-07
  • java集合的使用场景有哪些
    Java集合框架提供了一组接口和类,用于存储和操作数据。以下是一些常见的Java集合使用场景:1. 存储和操作一组对象:Java集合...
    99+
    2023-08-30
    java
  • java容器的使用场景有哪些
    Java容器的使用场景有很多,以下是一些常见的使用场景:1. 存储和操作数据:Java容器可以用来存储和操作各种类型的数据,例如Li...
    99+
    2023-09-21
    java
  • java中线程池的优点有哪些
    本篇文章给大家分享的是有关java中线程池的优点有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程...
    99+
    2023-06-14
  • vuex中有哪些使用场景
    这篇文章将为大家详细讲解有关vuex中有哪些使用场景,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。vue是什么Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作