阅读代码就像阅读犹太法典
来源:广州中睿信息技术有限公司官网
发布时间:2012/10/21 23:25:16 编辑:admin 阅读 861
导读:AlanSkorkin写过一篇文章,讲述他为什么喜欢阅读他人代码,并建议其他同行也如此。可理解为:阅读优秀代码是提高开发人员修为的一种捷径。微软的资深软件工程师EricLippert在答复同行

  导读:Alan Skorkin 写过一篇文章,讲述他为什么喜欢阅读他人代码,并建议其他同行也如此。可理解为:阅读优秀代码是提高开发人员修为的一种捷径  。微软的资深软件工程师 Eric Lippert 在答复同行 JeremyK 的问题时也感叹阅读代码很难

  Seth Gordon 给 Joel Spolsky 发过一封电子邮件,分享有关阅读他人源码的一些不错建议。以下是邮件的译文:

  在以色列的神学院学习 8 个月后,我开始在波士顿当一个技术作家。

  一年多前,我和一位同事正试图解释一个 Yacc 和 Perl 的怪题,我们打印了部分文档。我们坐下来看代码输出并逐行讨论。“现在,由于 Yacc 的工作方式,当遇到*this*这样的数据时,它就将运行*this*函数…… *this* 这一行是做什么的?就*this*这一点,这个混乱的数据结构看起来像什么?

  另一位同事问事情进展如何,我告诉他,“这就像在阅读犹太法典(Talmud)。”

  下面就是犹太法典的阅读战术,我认为同样适用于阅读源码:

  1. 结对进行,一个一个相互自言自语读代码。(编注:应该轮着解释代码。)

  2. 讨论。如果你的搭档说“这个是X的意思”,当你并不理解或者你有其他看法时,请他作出解释。

  3. 有时候,当在处理一段文字(代码)时,很容易找出你能看懂的两部分。所以,如果有段文字(代码)难住你了,可尝试跳过,稍后返回再看。(最终还是要回到该处的。)

  4. 阅读原文,既要“从内看”,也要“从外看”。“从内看”就是一个字一个字地把原文解释成英文(或你的母语);“从外看”就是把一段文字诠释通顺的段落。如果只“从内看”,你会只见树木不见森林;如果只“从外看”,你会只有个宽泛的猜测,也没有核实细节。

  (Joel Spolsky  )谢谢你,Seth!很好的想法!

  结语

  文章开头提到的 JeremyK ,他对阅读不熟悉代码的看法是,自己重写。 关于阅读代码,如果您有其他建议,欢迎在评论或微博中分享。

联系我们CONTACT 扫一扫
愿景:成为最专业的软件研发服务领航者
中睿信息技术有限公司 广州•深圳 Tel:020-38931912 务实 Pragmatic
广州:广州市天河区翰景路1号金星大厦18层中睿信息 Fax:020-38931912 专业 Professional
深圳:深圳市福田区车公庙有色金属大厦509~510 Tel:0755-25855012 诚信 Integrity
所有权声明:PMI, PMP, Project Management Professional, PMI-ACP, PMI-PBA和PMBOK是项目管理协会(Project Management Institute, Inc.)的注册标志。
版权所有:广州中睿信息技术有限公司 粤ICP备13082838号-2