恩,做的确实不错,但是,做的还不够,除非你是门门考试都 100 的学霸,否则,借助一些工具还是比较稳妥的办法。
在这里简单介绍一个代码分析工具 RubyCritic,这是一个专门针对 Ruby 的一个静态代码分析工具。其它语言的,也有相似功能的工具链,我就不做介绍了。
这是一个命令行工具,第一步就是添加到你的 gem 库中,当然,还可以使用 guard 自动化分析。(Ruby 的世界,你懂得~)第二 step,在 console 运行【RubyCritic】命令,就像这样:
在命令的最后,会生成一个静态页面。长这个样子:
x 轴代表改动频率,Y 轴代表代码复杂程度
这是分析结果的 overview,超过 200 的复杂度的,基本都是坏代码。
再看看 code 里的内容:
对不同文件按照改动频率、复杂度、重复度和坏味道 4 个维度进行综合评定代码质量等级(和美国考试的成绩打分规则一样)。
RubyCritic 对代码分析的原理,其实就是分析一些,被它认为是坏代码的点。注意,我这里使用的措辞是“被它认为,所以,有时候,它不是绝对的正确。”还可以查看具体的类文件中的代码质量问题。
更多的介绍,详见 https://github.com/whitesmith/rubycritic
下面,我们针对 RubyCritic 给我们的一些坏代码的点,有针对性的做些代码调整。
这里使用 git diff 比较新旧版本的差异。operator 原来是实例方法,代码行 7,并且里面还有一个 if 结构体。started_time_and_node 原来是实例方法,代码行 4,并且里面还不止一个 if 结构体。
笔者 review 的方式:
以上部分,属于语法层面的奇技淫巧。
第二部分,我们从设计角度分析一下。
它的代码行只有 141 行,方法也只有 7 个。但是评级却是 C。再看看代码分析细节,这里就展现一小部分,简直就是惨不忍睹,不好意思全展现给大家看了。
没有人会一开始就这样写代码,这种坏代码,永远都是渐渐变馊的。不过笔记仔细想来,当年遇到过比着还馊 1000 倍的代码(1000 倍都不算过分)。
这是笔者做的第一版重构结果。
第二版的改动计划是,引入 work-job 的模式,并发执行 4 个 job。
第三版改动计划就是利用回调方式,去掉与该类不相干的代码,将逻辑分装到行为类里。
好了,写到这里,基本的代码层面的优化思路就这些了,其它就是开支散叶的过程,这里就不冗余了。下一节,咱俩聊一聊性能优化的一些思路。