热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

优化代码时做出正确的决定

您手头有一项优化任务。太好了–您终于有可能做一些有趣的事情,而不用执行另一个发票处理屏幕。优化任务(希望)与某些非功能性要求相关联

您手头有一项优化任务。 太好了–您终于有可能做一些有趣的事情,而不用执行另一个发票处理屏幕。
优化任务(希望)与某些非功能性要求相关联,例如应用程序每秒必须处理的事务数或允许的每个事务的最大时间。



现在,您已经确定了应用程序中导致性能问题的部分。 您的应用程序的这一部分使用特定的算法。 您正在考虑将解决方案切换到另一种实现方式,并希望评估性能影响。 正如我们在前一篇文章中所讨论的那样 ,您明智地选择了每秒的用户事务数作为度量标准。 您使用旧的实现来运行压力测试,写下每秒实现的操作数,然后使用新的实现来运行相同的压力测试,写下每秒的新操作数。

接下来,您比较数字并做出一些决定。 这些决策中的一些可能包括对新的实施方案进行进一步的性能测量和/或优化的要求。 让我提出一些非常简单的示例:

  • 使用旧算法,需要1,000笔交易,耗时100秒
  • 使用改进的算法,相同的1,000个事务耗时90秒

大! 新版本更快! 您对该算法所做的更改使您的性能提高了10%。 现在,您可能需要在优化算法的基础上,根据有关后续步骤的信息做出进一步的决策。 但是,让我们考虑更多的信息:花费在垃圾收集上的时间。 您可以从GC日志中提取总的GC暂停时间。 那是您的应用程序停止进行世界各地的GC工作所花费的时间。 然后我们可以得到以下图片:

  • 使用旧算法,需要1,000笔事务处理100秒,其中GC暂停使用了20秒
  • 使用改进的算法,1,000个事务花费了90秒,而GC暂停花费了27秒

我们可以从这些信息中得出什么? 首先,算法的运行时间从100 – 20 = 80秒减少到90 – 27 = 63秒,加快了21%。 其次,GC占用您大约30%的CPU时间。 基于此,您的进一步算法的优化计划不仅应着眼于运行速度,还应着重于减少内存使用量和GC时间。

您应该如何决定选择哪个方向? 为了回答这个问题,我们应该调查您的性能要求。 也许您已经满足了您每秒需要处理多少个事务的要求。 但是所有交易是否都在短时间内处理? 也许您最初只测量每秒事务数的明智想法可能不是最好的想法?

这些技术要求可以转化为两个不同的方面,即吞吐量和延迟。 您当前的工作已提高了吞吐量,但可能会由于引入更多和/或更长的GC暂停而延迟了延迟。

NFR将指导您算法的进一步优化。 假设您仍未达到吞吐量要求。 您接下来的步骤是什么?

考虑到您的实现在GC暂停上花费了30%的时间 ,仅这个事实就应该引起危险。 在典型情况下(是的,我知道这就像测量医院的平均温度并据此做出决定), GC暂停时间不应超过总时间的5% 。 而且,如果您超过10%,则极有可能您应该对此采取某些措施。

减少GC暂停的第一步是调查JVM配置。 也许您只需要增加最大堆大小(-Xmx)? 也许您应该调整世代大小( -XX:NewRatio , -XX:SurvivorRatio …)? 也许您应该尝试使用其他垃圾收集器( -XX:+UseConcMarkSweepGC , -XX:+UseParallelGC …)? 根据您的应用程序,正确的答案可能是更改以上各项的组合,或者对其中一些进行更改,或者根本不提供任何帮助。

当配置JVM无法提供足够的结果时,下一步就是调查您的数据结构。 也许可以通过更改源代码来减少GC暂停。 也许您可以摆脱原语周围的所有包装器类,并显着减少开销? 也许您可以看看所使用的Collection类并减少造成的开销? 还是对于某些特殊情况,当您的算法不断地创建和销毁相同的对象时,也许对象池化是一个好主意?

并且在上述情况下,仅在此之后,您才可能真正想开始减少算法本身带来的开销。 在某些特殊情况下,这可能会导致您发现划分速度太慢。 而且,您需要找到一种巧妙的方法,用数据结构所支持的更便宜的操作来代替它。 否则每次写入java.util.concurrent.atomic.AtomicBoolean所伴随的内存障碍太昂贵了。 但是,让我将这些情况留给另一个故事,当我描述我一生中处理过的一些最奇怪的CPU浪费时。

结论–如果您要优化代码,请确保已对吞吐量和延迟的要求进行了仔细考虑。 而且您不会只坚持一种优化技术。 希望阅读本文后,您现在可以在自己的武器库中使用更多工具。

参考: Plumbr Blog博客上的JCG合作伙伴 Nikita Salnikov Tarnovski 优化代码时做出正确的决定 。

翻译自: https://www.javacodegeeks.com/2012/12/making-the-right-decisions-when-optimizing-code.html




推荐阅读
  • 关于CMS收集器的知识介绍和优缺点分析
    本文介绍了CMS收集器的概念、运行过程和优缺点,并解释了垃圾回收器的作用和实践。CMS收集器是一种基于标记-清除算法的垃圾回收器,适用于互联网站和B/S系统等对响应速度和停顿时间有较高要求的应用。同时,还提供了其他垃圾回收器的参考资料。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 阿里Treebased Deep Match(TDM) 学习笔记及技术发展回顾
    本文介绍了阿里Treebased Deep Match(TDM)的学习笔记,同时回顾了工业界技术发展的几代演进。从基于统计的启发式规则方法到基于内积模型的向量检索方法,再到引入复杂深度学习模型的下一代匹配技术。文章详细解释了基于统计的启发式规则方法和基于内积模型的向量检索方法的原理和应用,并介绍了TDM的背景和优势。最后,文章提到了向量距离和基于向量聚类的索引结构对于加速匹配效率的作用。本文对于理解TDM的学习过程和了解匹配技术的发展具有重要意义。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 本文介绍了在Python张量流中使用make_merged_spec()方法合并设备规格对象的方法和语法,以及参数和返回值的说明,并提供了一个示例代码。 ... [详细]
  • 压力测试工具  ab
    ab是Apache自带的一个压力测试工具,命令行,是ApacheBench命令的缩写。ab的原理:ab命令会创建多个并发访问线程ÿ ... [详细]
  • 压力测试_单节点数据库的压力测试
    mysqlslap是mysql自带的基准测试工具,优点:查询数据,语法简单 ... [详细]
author-avatar
549696530_c1f5e8
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有