QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

代码优化是一把双刃剑

  • 2021-02-20
  • 本文字数:1495 字

    阅读完需:约 5 分钟

代码优化是一把双刃剑

为何优化并不总是一个好主意?


优化是对已经开始工作的单元进行改进的过程。对于终端用户或客户来说,这就像是樱桃一样诱人。出于同样的原因,代码优化在软件行业非常流行。但是优化代码真的总是有益的吗?我在软件行业已经工作五年多了,我可以告诉你的是,代码优化是一把双刃剑。如果处理不当,它可能弊大于利。

 

在软件术语中,我们使用术语“过早优化”来表示不好或不必要的优化。说起来容易做起来难,实际上,发现过早优化并不容易。在这篇文章中,我将与大家分享一些可以帮助你进行优化并避免代码过早优化的方法。

 

让我们开始吧。

万恶之源

代码优化是修改软件系统的过程,目的是使程序执行得更快,或使其能够在运行时使用更少的内存或其他资源。大多数开发人员相信代码优化是软件开发过程中必要的一步。但事实上并非如此。永远不要过早尝试优化应用程序的代码——或只在需要时才尝试优化代码。


过早优化是编程中的一切(或至少大部分)恶之根源。——唐纳德·克努斯


基于简洁的思想写成的源代码足以满足 99%情况下的性能需求。而且这将极大地提高应用程序的可维护性。

 

例子:

  • 在 C 语言中使用指针运算代替数组符号,包括使用诸如以下风格的代码:

for (p = q; p < lim; p++)
复制代码

 

  • 在 Lua 中重新绑定全局变量到局部变量,例如:

local table, io, string, math= table, io, string, math
复制代码

 

简而言之,如果一种技术使程序更难以理解,那么这就是过早优化

 

过早优化的最大问题是,它可能会引入意料之外的 bug,并可能浪费大量资源和时间。

 

“毫无疑问,效率的圣杯导致了滥用。程序员浪费了大量的时间来考虑或担心他们程序非关键部分的速度,而这些提升效率的尝试实际上会对调试和维护产生强烈的负面影响。我们应该忘记那些小的效率提升,比如说 97%的情况下,过早优化是万恶之源。

 

然而,我们不应该错过这关键 3%的优化。一个好的程序员不会因为以上推理而沾沾自喜,他会明智地仔细审查关键代码,但必须是在这些关键代码被识别之后。”


— Structured Programming with go to Statements (1974)

为什么开发人员倾向于过早优化

人们往往在不知不觉中追求过早优化,这可能有多种原因,包括:

  • 他们很容易花大量时间思考不重要的事情,以取得错误的进步感。

  • 他们只是不知道如何提前计划,并弄清楚在开发过程的每个阶段他们应该从事哪些任务。

  • 他们甚至会在开始尝试之前就规划好未来的行动方案,因为纸上谈兵总是更容易。

  • 代表了一种现象,即人们花费不成比例的资源来处理相对次要的问题。 

如何避免过早优化

在确定是否应该优化某些东西时,你应考虑一些因素,并问自己几个重要的问题。

 

以下这些问题可以帮助你决定是否值得这么做:

 

  • 我们为什么要优化?

在此阶段是否真的有必要进行优化,或者您只是因为要避免处理其他问题而专注于此?

 

  • 优化的好处是什么?

您应该有充分的理由来优化它,因为它将需要资源。它应该足以值得每个人花费时间,并且对项目有重大的影响。

 

  • 优化的成本有多高?

实现优化需要多少团队努力和时间?这是否会影响项目正在进行中的工作流程?这类事情需要在执行之前进行评估。

 

  • 优化的后果是什么?

这种优化在不久的将来会给您带来什么问题?会增加应用程序的测试范围吗?

 

在回答了所有这些重要问题并在团队中进行讨论之后,就可以决定是否需要优化了。

最后的想法

任何以性能为名使您的代码难以理解的编码实践都是不值得的。在没有可衡量的性能问题的情况下,您不应该进行优化,因为这是过早优化,就算你认为自己会获得性能上的提升也不要这样做。

 

像其他所有性能问题一样,你应该在开始任何优化之前都进行评估。

 

英文原文链接:


https://codeburst.io/code-optimization-is-like-a-double-edged-sword-86ba957386cf

2021-02-20 16:562159

评论

发布
暂无评论
发现更多内容

Serverless 成本再优化:Knative 支持抢占式实例

阿里巴巴云原生

阿里云 Serverless 云原生

借助淘宝评论API,商家轻松掌握市场动态与商机

技术冰糖葫芦

API 接口 API 文档 pinduoduo API

数栈+AI:数栈V6.2创新发布,让数据开发更智能

袋鼠云数栈

大数据 AI 信创 AI技术 大模型

润和软件成功举办2023-2024年openEuler技术委员会会议

科技热闻

SD-WAN在国际教育机构中的应用

Ogcloud

SD-WAN 网络sdn 企业组网 SD-WAN组网 SD-WAN服务商

Saturn 4 Ultra土星引领光固化3D打印消费新风尚,大众普及指日可待

科技热闻

万界星空科技工时管理系统功能介绍

万界星空科技

mes 工时管理 生产管理 车间管理 工时绩效

NFTScan | 04.15~04.21 NFT 市场热点汇总

NFT Research

NFT\ NFTScan

高通将支持 Meta Llama 3 在骁龙终端运行;特斯拉中国全系车型降价 1.4 万元丨 RTE 开发者日报 Vol.189

声网

华为Mate X5升级HarmonyOS 4.2 大屏互动超有趣

最新动态

阿里巴巴1688商品API实战:批量抓取价格、标题、图片及库存数据

技术冰糖葫芦

api 货币化 API 接口 pinduoduo API

双线高防服务器的选择与配置:保障在线业务的安全与稳定

一只扑棱蛾子

高防服务器

下载量超 200 万,最近频繁登上热搜的 AI 程序员,大家怎么看

阿里巴巴云原生

阿里云 云原生 通义灵码

Taylor Swift全新专辑上线华为音乐,谱写爱与诗歌音符

最新动态

拥抱AI技术:6月22-23日全球金牌CSM认证课程 · Jim老师引导讨论AI & Agility话题

ShineScrum

ScrumMaster 敏捷认证 Scrum官方认证

Giants Planet 宣布推出符文,建立在坚实价值的基础上

加密眼界

短视频评论抓取拓客软件|评论采集爬取下载工具

Geek_16d138

爬虫工具 爬虫技术 好用的软件分享

捷途山海T2:通勤低成本,日常出行更经济

极客天地

SD-WAN为什么在亚太地区普及?

Ogcloud

SD-WAN 企业网络 SD-WAN组网 SD-WAN服务商 SDWAN

漫画项目管理 | 项目目标不合理,该如何修订?

禅道项目管理

项目管理 职场 pmp 能力提升 项目管理PMP

​下载量超 200 万,最近频繁登上热搜的 AI 程序员,大家怎么看

阿里云云效

阿里云 AI 云原生

「杭州*康恩贝」4月26日PolarDB开源数据库沙龙,开启报名!

阿里云数据库开源

阿里云 技术交流 开源数据库 polarDB 康恩贝

短视频评论ID提取采集软件|评论批量爬取下载工具

Geek_16d138

短视频创业 评论系统 好用的软件分享

EasyMR6.2 全面解读:四大功能深度优化,解锁全新大数据处理和计算体验

袋鼠云数栈

hadoop 数据处理 计算引擎 数据计算 国产化替代

软件测试学习笔记丨后端接口基本开发 - spring boot发送 POST请求

测试人

软件测试

MES系统 DE 生产绩效功能及分析

万界星空科技

绩效管理 生产管理系统 mes 工时管理 生产绩效

短视频评论提取工具软件介绍|评论采集下载爬取

Geek_16d138

代码优化是一把双刃剑_语言 & 开发_Shubham Pathania_InfoQ精选文章