请问如何权衡优化的收益和成本?
什么时候该优化? 什么时候不该优化?
![]() | 1 liu233 2018-08-27 10:17:16 +08:00 我司的原则就是做出来就好,优化个锤子。 但是我的东西一般有时间就瞎捣鼓捣鼓。 |
![]() | 2 4u1kto 2018-08-27 10:21:17 +08:00 楼下极有可能会有推这本书的《重构 改善既有代码的设计》 |
3 zqyisasd 2018-08-27 10:32:02 +08:00 楼上说的对 |
![]() | 4 4u1kto 2018-08-27 10:37:28 +08:00 但是我水平比较次,这本书对我没用 |
![]() | 5 metrxqin OP @4u1kto 我看过这本书,它比较侧重局部、小规模的重构,但我需要的是软件设计上的优化启发式原则。就比如缓存系统,什么时候应该引入缓存,什么应该缓存,什么不应该缓存。 |
6 MeteorCat 2018-08-27 12:27:12 +08:00 via Android 先把功能实现,前期过度的优化是崩溃的开始(把后期的优化应用到前期上,堵死了后期的优化) |
![]() | 7 jpmorn 2018-08-27 12:41:38 +08:00 @metrxqin https://github.com/donnemartin/system-design-primer/blob/master/README-zh-Hans.md system-design-primer |
9 AllOfMe 2018-08-27 13:00:58 +08:00 目的非常明确了而且很有必要,才开始优化。否则最开始乱优化,反而会导致问题的复杂度加大 |
10 FrailLove 2018-08-27 13:14:07 +08:00 找到关键点来优化 你把一个半夜运行的定时任务从 3 小时优化到 1 小时并没有什么卵用 把用户点击按钮从 3 秒优化到 1 秒意义就很大 |
![]() | 11 weizhen199 2018-08-27 13:22:28 +08:00 给多少钱(工时)优化多少 |
![]() | 12 Rizio 2018-08-27 14:31:03 +08:00 面向 money 优化 |
![]() | 13 szq8014 2018-08-27 14:31:55 +08:00 闲得没事干的时候或者性能到瓶颈的时候 |
![]() | 14 metrxqin OP 也就是说,不得不优化的时候才优化。 |
15 feng1234 2018-08-27 15:16:00 +08:00 难道不是从 sleep ( 60 )更改为 sleep ( 30 )嘛,手动斜眼 |
![]() | 16 jswh 2018-08-27 15:26:32 +08:00 @metrxqin 你的这个问题其实是一个很经验化的问题,也就是要 case by case 的问题。这种优化很多时候是一种取舍,所以很难说一定做什么,一定不做什么。比如缓存的引入,一定会增加系统的复杂度,何时刷新缓存,如何刷新缓存,缓存数据和落地数据更新读取顺序等等问题,大多时候都要具体情况具体分析,很少能一概而论。 感觉这个是一个软件工程的问题,没有上过这个方面的课程,仅仅经验之谈。 |
![]() | 17 wysnylc 2018-08-27 16:01:28 +08:00 先业务,再谈性能 |
![]() | 18 nutting 2018-08-27 16:53:24 +08:00 先多 sleep 一会儿,客户要求的时候就好做了 |
![]() | 19 rockyou12 2018-08-27 17:05:29 +08:00 没有性能问题,就不要优化。 其实可以很简单的考虑,不管是谁写,代码写得越多,错得越多,所以首先代码越少,bug 就越少。优化什么的除非开始就可以预见会有性能问题,不然就不要考虑。 |
20 scmod 2018-08-27 17:13:03 +08:00 先实现功能吧,免得需求变来变去最后白搞,一般加上 TODO:之类的以后有必要时候提示下自己就好了 |
![]() | 21 shangshicc 2018-08-27 18:07:28 +08:00 ![]() 1.实现功能,最基本的要做到不要有重复代码 2.是否做性能优化要看是否有性能瓶颈,是否做代码的结构优化主要看你是否对于当前的代码足够满意,或者说你自己能不能看懂,有没有觉得维护性好,如果每次添加新功能时觉得整体设计不合理的话就要修改设计。 |
![]() | 22 noNOno 2018-08-27 18:29:57 +08:00 |
![]() | 23 lotmany 2018-08-27 18:43:21 +08:00 via iPhone 我所接触到的优化 先加带宽 - 换 SSD - 内存翻倍 - 加个服务器负载 还不行 上面再来一遍 |
![]() | 24 lance7in 2018-08-27 19:28:49 +08:00 看工资 30K 就做 30K 级别的优化 80K 就做 80K 级别的优化 |
![]() | 25 xuanbg 2018-08-28 07:36:47 +08:00 先实现功能,然后有时间就优化,没时间就挤出时间来优化。 只有通过优化代码,才能让自己的能力不断提高。 |
![]() | 26 hanxiV2EX 2018-08-28 08:26:15 +08:00 via Android 优化?不可能的,最多把代码整好看点 |