阅读代码就像阅读犹太法典

导读: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 ,他对阅读不熟悉代码的看法是,自己重写。 关于阅读代码,如果您有其他建议,欢迎在评论或微博中分享。

打赏支持我翻译更多好文章,谢谢!

打赏译者

打赏支持我翻译更多好文章,谢谢!

任选一种支付方式

收藏 评论

关于作者:黄利民

伯乐在线联合发起人,关注 IT 和互联网。 个人主页 · 我的文章 · 97 ·  

相关文章

可能感兴趣的话题



直接登录
跳到底部
返回顶部