- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Java程序性能优化笔记
Java程序性能优化笔记并行程序开发及优化Mster-work模式其工作示意图如上,其核心思想就是将任务进行分解成多个子线程去执行,这样可以加快任务的执行速度。 其实现主要有以及角色 .Master类:进行任务的提交,worker的分配,会维护一个任务列表。 Worker类:实现任务的执行。Mster类和worker类会共同维护一个任务队列 多开几个线程去执行worker对应的任务,每个线程都是由work去执行的,线程引用了worker。上面是对应的类图。Executor框架为了更好的控制并发,jdk内置了Executor的框架,帮助开发人员有效的进行线程控制,其核心成员如下图所示。executor提供了很多的有用的功能,下面是Executors提供的工厂类方法: public static ExecutorService newFixedThreadPool(int nThreads) { return new ThreadPoolExecutor(nThreads, nThreads, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueueRunnable());}public static ExecutorService newCachedThreadPool() { return new ThreadPoolExecutor(0, Integer.MAX_VALUE, 60L, TimeUnit.SECONDS, new SynchronousQueueRunnable());} public static ExecutorService newSingleThreadExecutor() { return new FinalizableDelegatedExecutorService (new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueueRunnable()));}上面所有的实现,其实底层都是用到了ThreadPoolExecutor类。其构造方法如下: public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueueRunnable workQueue,RejectedExecutionHandler handler)corePoolSize:指定线程池的数量maximumPoolSize:最大的线程池数量keepAliveTime:当线程超过corePoolsize的时候,多余的空闲线程的存活时间。workQueue:任务队列handler:拒绝策略有界任务队列的执行:当前线程数量小于coresize时,提交的线程会创建新的线程,但当当前线程已经是coresize的时候,此时任务会提交到有界任务对了,当有界任务队列满时,并且线程数量小于max的时候会创建线程,如果已经达到了max,那么此时任务会执行丢弃处理的策略。无界对列任务:当线程池数量已经达到了coresize的时候,还有任务进行提交的时候,此时任务是放到无界队列中的,如果说此时没有空闲的线程,那么无界对列会保持快速增长,直至系统资源耗尽。Executors方法说明newFixedThreadPool(int nthreads)此方法返回一个大小固定的线程池,且coresize和maxsize是大小一样的,所以线程池不会动态的增长,但是他使用了一个无界的队列,当任务提交非常频繁的时候,该队列会迅速的膨胀,从而耗尽系统资源。newCachedThreadPool返回一个没有限制大小的线程池,当线程池没有可以用的线程的时候会立即创建线程,且该方法使用了一个SynchronousQueue队列,这是一个直接提交任务的队列,它没有容量,每次提交都会等待一个删除操作。使用此队列必须使用很大的maximumPoolSize值,否则很容易执行异常策略。如果任务提交很频繁,且任务执行的时候又不快的时候,很容易出现系统资源耗尽的情况。ThreadPoolExecutor解析当客户端进行提交任务时,其实执行的是ThreadPoolExecutor的excute方法,在这个方法中所有的任务都是在内部类的work中去执行的,其时序图如下:Submit方法其实调用的AbstarctExecuteService方法,这个里面执行了execute方法,而这个方法是在其ThreadPoolExecutor中实现的,其execute方法的时序图如下: 先去判断poolsize是否小于
您可能关注的文档
- JavaEE核心技术(第3章 JavaEE规范2)-Servlet.ppt
- JavaScript+jQuery开发框架课程设计.doc
- JavaScript数组中的22个常用方法.docx
- JavaScript期末测试题.doc
- javascrpt-BOM.ppt
- JavaSE_09_多线程.docx
- JavaSE_13_常用类.ppt
- JavaSE基础教程.docx
- javaStudyNote.docx
- java_8多线程.ppt
- 2024年秋季新湘教版地理7年级上册全册教学课件.pptx
- 2024年秋季新冀教版英语三年级上册全册课件.pptx
- 统编版语文四年级下册全册课件(2025年).pptx
- 湘少版英语五年级下册全册教学课件(2025年).pptx
- 统编版语文五年级下册全册教学课件(2025年2月修订).ppt
- 统编版语文五年级下册全册教学课件(2025年2月修订).pptx
- 统编版语文五年级下册全册课件(2025年).pptx
- 2024年秋季新北师大版七年级上册数学全册大单元整体设计教学课件(新版教材).ppt
- 2024年秋季新北师大版七年级上册数学全册大单元整体设计课件.ppt
- 2024年秋季新北师大版七年级上册数学全册大单元整体设计课件.pptx
最近下载
- 季度查漏补种登记表.doc VIP
- GB50318-2017 城市排水工程规划规范.pdf VIP
- 2025至2030中国移动视频监控行业市场占有率及投资前景评估规划报告.docx VIP
- 汽车门锁及空调故障.pptx VIP
- 生态环境数据分级管理指南.pdf VIP
- 八省联考2026届高三年级12月检测训练(T8联考)化学试卷(含答案详解).pdf
- 2022春(六下)顺 - 填空题1.docx VIP
- T∕CACM 1319-2019 慢性阻塞性肺疾病中医诊疗指南.docx VIP
- GZ021 化工生产技术赛项(正式赛卷)仿真操作模块方案及评分6.doc VIP
- 金蝶云星空完整版.pdf VIP
原创力文档


文档评论(0)