Q1:在Java并发编程中,如何扩展和优化线程池?

在java中多线程并不陌生,在一定的范围内,多线程数量的增加会明显提升整个系统的吞吐性能,但是线程本身会极大的耗费内存空间,线程的频繁创建和回收也极其占用CPU资源,多线程甚至会拖垮整个服务!

所以,线程的利用必须掌握在一个度,太少的线程数可能会浪费CPU资源,而太高也极有可能反而降低整个应用性能;

线程池:基于使用多线程存在的问题,JDK提出了线程池技术,类似于数据库连接池,都是保持池中部分线程活跃状态,在需要使用线程的时候,直接从线程池中获取,使用。当线程使用结束,就进行回收(直接放回池中等待,而不是GC),这样就能避免了线程的频繁创建和回收。

JAVA中的线程池:JDK提供了线程池框架Executor,帮助程序更好的管理线程。总的结构如下截图:

比较常见的线程池对象获取方式为:

①newSingleThreadExecutor():返回单线程的线程池,一个接一个的处理任务,线程异常的时候,会创建新的线程替代; ②newFixedThreadPool:在达到最大线程之前,有一个任务就创建一个线程,直到达到最大线程数量; ③newCachedThreadPool:动态的设置最合适的线程数量,最大为JVM能够支持的大小; ④newScheduledThreadPool:指定线程数量,并周期性的执行任务; ⑤newSingleThreadScheduledExecutor:指定线程数量1个,并周期性的执行任务;

从源码来看,上面几种线程池底层都是封装的ThreadPoolExecutor对象,查看源码可知比较重要的属性(对象)截图如下:

定义了线程池中的线程数量,最大线程池数量,线程工厂(用于线程的创建),workQuere任务队列,handler拒绝策略等属性,用于线程池的对象初始化和任务调度!

下图是ThreadPoolExecutor对象中的execute方法截图:

解释如下:

1,当前线程总数小于核心线程数,则通过addWorker进行执行;

2,否则通过wordQueue.offer提交到等待队列,

3,进入等待队列失败,则通过addWorker提交到线程池,失败则执行拒绝策略;

线程池有多种拒绝策略:直接抛出异常,或者丢弃无法处理的任务等等,此处不做详细讨论。。

线程池的扩展:JDK允许开发人员自主扩展线程池,通过提供的beforeExecute,afterExecute,terminated三个接口可以像处理AOP一样方便的管理线程池,可自行实现状态跟踪,调试信息等用以监控线程池!

线程池的优化:线程池的优化主要针对线程数量进行,一般来说只要使用的不是最大最小线程数量都可以,但是具体的还要根据场景,参考CPU核心数,等待时间等因素来判断最合适的线程数,比如是批量运算这种密集的CPU执行,则线程数设置为CPU核心数即可,如果有大量阻塞,则可以使用CPU核心数的偶数倍数,在有一本书中得出了一个公式如下截图:

jdk中的线程池技术比较完善,加上其他的多线程技术,促使JAVA成为高并发领域的佼佼者,最近一直在分享JAVA技术,得到很多朋友的鼓励,在此表示感谢,我也会一直持续的进行分享,敬请关注。。

java 10个线程_Java线程池创建10个线程相关推荐

  1. terminated 线程_Java【多线程系列】JUC线程池—2. 原理(二)、Callable和Future

    在"Java多线程系列--"基础篇"01之 基本概念"中,我们介绍过,线程有5种状态:新建状态,就绪状态,运行状态,阻塞状态,死亡状态.线程池也有5种状态:然而 ...

  2. java 1000个线程_java,一个程序建立1000个线程,每一个线程加1到一个变量sum。

    1.程序建立1000个线程,有可能造成系统创建大量线程而导致消耗完系统内存,还会增加创建和销毁线程上所花的时间以及系统资源的开销 2.在创建线程数多的情况下,可以考虑使用线程池 以下是Java自带的几 ...

  3. java学习笔记 多线程(一)创建多线程,线程常用方法

    首先是进程和线程的区别,进程就是像打开csgo.exe就是一个进程,然后打开LOL.exe又是另外一个进程了. 而线程呢,就是在同一进程内部,发生的事情. 那么就开始了解线程! 创建多线程: 线程有三 ...

  4. java多线程交替打印_java多线程 更优雅的实现线程同步:交替打印A、B LockSupport实现...

    一 问题概述 线程或者进程之间有两种关系 同步和互斥,我们通常实现同步方法是使用线程的等待唤醒机制,而等待唤醒机制的使用是建立在互斥的继承上的.但是同步线程并不一定是必须要实现互斥的.比如一个线程打印 ...

  5. 并发编程——线程——线程的理论和创建以及守护线程

    一.什么是线程 线程是操作系统能够进行运算调度的最小单位. 它被包含在进程之中,是进程中的实际运作单位. 一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任 ...

  6. java 轻量级文件数据库_Java:如何创建轻量级数据库微服务

    java 轻量级文件数据库 基于云的Java数据库应用程序的数量每分钟都在增加. 许多组织部署了数百甚至数千个微服务实例. 但是,相对于运行时环境,大多数应用程序会带来惊人的不必要开销. 反过来,这会 ...

  7. java 镶嵌创建线程_Java多线程——之一创建线程的四种方法

    1.实现Runnable接口,重载run(),无返回值 package thread; public class ThreadRunnable implements Runnable { public ...

  8. java怎么看具体被挂起的线程_Java知多少(65)线程的挂起、恢复和终止

    有时,线程的挂起是很有用的.例如,一个独立的线程可以用来显示当日的时间.如果用户不希望用时钟,线程被挂起.在任何情形下,挂起线程是很简单的,一旦挂起,重新启动线程也是一件简单的事. 挂起,终止和恢复线 ...

  9. java 多线程共享数据_Java多线程学习:多个线程间共享数据

    多个线程访问共享对象和数据的方式有两种情况: 1.每个线程执行的代码相同,例如,卖票:多个窗口同时卖这100张票,这100张票需要多个线程共享. 2.每个线程执行的代码不同,例如:设计四个线程,其中两 ...

最新文章

  1. GridView中实现CheckBox的全选
  2. java jni 方法描述,五、JNI提供的函数介绍(一):类和对象操作
  3. JAVA WEB_中间件
  4. 计算机网络asp视频教程,轻轻松松学编程!ASP互动视频教程
  5. 类文件Spring中空值的写法-java教程
  6. iOS-仿支付宝加载web网页添加进度条
  7. 6.3.1 强连通分支算法--Kosaraju算法、Tarjan算法和Gabow算法
  8. 华为历届笔试面试题整理大全
  9. CKplayer功能配置
  10. 有人说做运营死路一条,但他没搞清运营是做什么的!
  11. 未來用工新趨勢_2019年社会化用工成新趋势
  12. PLA-PEG2000-Maleimide,聚乳酸和马来西安亚楠修饰的PEG,MAL-PEG2000-PLA
  13. android启动其他apk,Android 启动apk的常用方法
  14. winpe装双系统linux_LINUX下安装WINDOWS双系统
  15. 英语一点都不懂怎么学,怎么快速学好英语?
  16. 黑马程序员————GUI(day22)
  17. oracle amm和asmm,在Oracle中,什么是ASMM和AMM?
  18. 【Opencv】-----倾斜图片转正
  19. 项目(day01网站流量指标统计)
  20. Golang Break、Continue跳出多层循环

热门文章

  1. linux 内核定时器(低精度) — 外部看门狗程序
  2. Java 基础常见知识点面试题总结(上),2022 最新版!
  3. 05【Verilog实战】AMBA 3 APB接口设计(附源码RTL/TB)
  4. 市场监管总局对《严重违法失信名单管理办法》征求意见
  5. 明明说好的 16g 内存卡实际却不足 15 g?
  6. 1000 0000补码是什么的原码
  7. 梦幻西游手游烹饪50到60_50个很棒的厨房,食物和烹饪图标集
  8. 完成乔布斯的梦想:一个免费wifi共享的乌托邦
  9. linux服务器杀进程,linux杀死进程命令[通俗易懂]
  10. Java中String类型与Map类型互转