公司对It资源成本越来越谨慎,总是要求我们在既定的设备下,稳定运行更多的服务,在“为了性能”决定开始优化之前,之前需要知道的事。
你到底为了什么而优化
如果在优化过程启动时搞不清楚为什么而优化,那么你基本会走向错误的道路。你需要清楚的理解你准备完成的目标和相关的优化选择。这些目标需要清晰而且简洁,简单到项目经理能够理解它,你需要在优化过程中始终坚持这些目标。在软件开发过程中,变更是常有的事情。你可能一开始想优化这个目标,然后又发现需要优化其他目标。事实也是如此,但是请把这些目标的变更记录清楚。
性能测试团队报告的性能缺陷可能是优化的主要目标,一方面它来自于开发人员之外的客观性能问题,另一方面这些缺陷报告会明确的指出存在哪些问题,是运行缓慢,还是磁盘换页频繁等等。开发人员从这些缺陷中开始入手优化,比自己空想出的性能目标要合理、客观的多。
小心对待优化的衡量标准
选择正确的衡量标准是优化的重要步骤。你需要利用这些标准来衡量自己的优化进度。如果衡量标准是错误的,那么你的努力就白费了。即使是正确的标准,也需要正确的运用。有时候,把主要精力放在应用程序运行时间最多的代码部分上市正确的做法。不过请记住,Unix/Linux内核在空闲循环(idle loop)中花费的时间最多。这里的问题是,如果你不小心对待,那么你可能会选择一个不能帮助你解决问题的衡量标准。
衡量标准的选择应该取决于哪些标准能够确实提高用户体验。例如,有关数据库的性能分析指标有很多,开发人员和性能测试人员需要确定哪些指标是真正影响应用程序速度的,是bufferpool的大小,还是数据库连接池的大小。这是一个渐进的认识过程。
优化且只优化关键部分
这是有效优化的关键。寻找能够达到目标(性能、资源)的代码部分并集中精力。一个典型的例子是把时间花费在优化数据库上,而实际的性能杀手是缓慢的网络连接。
不要被映入眼帘的表象所吸引。这些表象并不一定会解决你的问题。只是因为某些事情易于发现而且易于优化并不意味着它们值得关注。
高层次优化更好
一般来说,优化的层次越高,优化的效果就越明显。按此标准,最好的优化方法是寻找更好的算法。例如,在一些IT部门,员工花费几个月的时间来对某个软件做优化但是没有进展,然后找来一批新员工来做这些优化,他们很快就会发现性能的问题在于代码某处使用了冒泡排序或者某张数据库表增加了数以万条的记录等等。
建议大家花时间看看基本的应用架构,找找有没有可以优化的线索。但是,高层次优化不是银弹。一些基本的技术,比如把代码尽可能的移到循环体外面等等。
另外,高层次优化可以避免对代码细节的复杂重构。开发人员往往对低层次的优化最感兴趣,请控制住自己的欲望,从高处着手!
不要过早优化
开发人员有一种冲动,那就是在编码的时候就准备优化了。一般来说,这不是个好主意。有时候,开发人员并不确定这样的优化工作是否值得。例如,你可能通过移位操作来代替乘法操作,但是这种性能优化的做法会产生让人非常难以理解的代码。
最好把开发和优化工作分开,先开发出正确的代码,然后再优化。过早优化的问题在于开发人员会有意的对软件的架构设计和代码结构等做一些预先的设想,而其中有相当一部分都是多余操心的,你可能不得不对这些多余的部分再做优化。
依靠性能分析数据,而不是直觉
你以为自己知道软件系统哪里需要优化,但是直觉是第二位的,数据是第一位的。否则,你会发现可能把一段代码优化的非常快,但是实际上很少被调用。
优化的一个有效的策略是,你要根据所做工作对优化效果的影响来进行排序。在开始工作之前找到影响最大的“路障”,然后再处理小的“路障”。
不能指望优化解决所有问题
优化的重要法则之一是不能让优化解决所有问题,比如,提高运行速度会耗费更多系统资源。你必须为了主要的优化目标做出权衡。
分享到:
相关推荐
综上所述,Java代码优化是一个多方面的过程,涉及到对象管理、循环优化、异常处理以及数据结构的选择等多个方面。开发者应当具备良好的编程习惯和对Java语言特性的深入理解,才能写出既高效又易于维护的代码。此外,...
Java代码优化是一个持续的过程,它包含了许多细节和技巧,能够帮助开发者编写出更高效、更易于维护的代码。在这44条Java代码优化建议中,我们可以提炼出一些核心的知识点,为Java编程实践提供参考。 首先,关于为...
可能的代码结构会包括以下几个部分: 1. **定义目标函数**:根据实际问题定义多个目标函数,它们通常需要被封装为可调用的函数。 2. **编码与解码**:对问题的解决方案进行编码,例如使用二进制或实数编码,解码则...
总结来说,"top88_拓扑优化88行代码_99行_"是一个针对拓扑优化问题的代码优化实例,通过调整和改进代码,提高了计算效率,这对于需要进行大量计算的工程设计和科研工作具有重大意义。如果你有机会深入研究这段代码,...
本文将深入探讨几个针对DIV+CSS优化的方法,以提高代码效率,减少加载时间,提升用户体验。 首先,我们需要理解“DIV+CSS”布局的基本原理。DIV元素在HTML中通常用于创建网页的布局结构,而CSS则负责定义这些布局的...
总之,单片机代码优化不仅包括上述几个方面,还包括算法选择、指令选择、循环展开、条件编译等多种策略。这些优化方法的目的是充分利用有限的硬件资源,提高代码的执行效率,使得单片机能够在有限的资源条件下发挥...
代码可能包含以下几个关键步骤: 1. **模型定义**:定义梁的几何尺寸、材料属性和边界条件(例如简支约束)。 2. **载荷与约束**:设置中点的单位载荷和端部的固定约束。 3. **优化算法**:选择合适的优化算法,如...
在MATLAB环境中,实现RHC通常涉及以下几个步骤: 1. **系统建模**:首先,需要建立一个数学模型来描述系统的动态行为。这可以是线性或非线性的状态空间模型,或者更复杂的形式如差分方程。 2. **优化问题设定**:...
代码优化可以从以下几个方面着手: 1. **减少数据库查询**:优化SQL语句,避免不必要的JOIN操作,合理使用索引,减少数据库交互次数,都是提升性能的有效方法。 2. **减少冗余代码**:删除未使用的变量、函数和类...
代码可能包括以下几个关键部分: 1. 初始化:创建粒子群,随机生成每个粒子的位置(代表一个可能的解决方案)和速度。 2. 计算适应度函数:为每个粒子计算其对应的解决方案(调度方案)的性能指标,如总完成时间或...
在Matlab中实现PSO算法,我们需要定义以下几个关键步骤: 1. 初始化:随机生成一定数量的粒子,每个粒子对应一个解(解决方案),并设定初始速度。 2. 更新位置:根据当前速度和位置,以及个人最好位置(pBest)和...
学习和理解这些代码,可以帮助我们更好地掌握如何在MATLAB中进行无约束优化,从而解决实际问题。 例如,一个典型的MATLAB无约束优化代码流程可能如下: 1. 定义目标函数:这是我们要最小化或最大化的函数。 2. ...
在多目标优化问题中,我们通常需要同时考虑多个目标函数,以找到一组最优解,这些最优解在目标空间中形成帕累托前沿。在MATLAB中实现粒子群算法来解决这类问题,可以利用其强大的数值计算和可视化能力。 PSO的基本...
本资料集合主要涵盖了以下几个核心知识点: 1. **线性规划**:线性规划是最优化的基础,用于求解目标函数在一系列线性约束条件下的最大值或最小值。MATLAB中的`linprog`函数可以处理这类问题。 2. **二次规划**:...
该项目可能包括以下几个关键部分: 1. **问题定义**:首先,需要定义优化问题,包括初始和目标位置、时间约束、以及可能的速度和加速度限制。这通常涉及到设置数学模型,如微分方程或代数方程组。 2. **算法选择**...
代码通常会包括以下几个部分: - **参数设置**:如粒子数量、最大迭代次数、学习因子、惯性权重等。 - **初始化**:创建粒子群体,分配初始位置和速度。 - **目标函数**:定义多目标函数。 - **评价函数**:计算每...
在IT行业中,路径优化问题是一个重要的研究领域,特别是在物流、交通管理和供应链管理等领域有广泛应用。在本项目中,我们关注的是“matlab求解多车辆,多车型、带有时间窗路径优化问题”,这是一个复杂的数学模型,...
在多目标优化问题中,NSGA(非支配排序遗传算法)系列是常用的一种高效解决方案。这里我们主要讨论的是NSGA3,这是一种针对多目标优化问题的改进型遗传算法,其在NSGA-II的基础上进行了优化,提高了求解质量和效率。...