程序员的进步从阅读自己的老代码开始

jopen 9年前

  英文原文:Look at your old code

  关于如何成为一个更优秀的程序员这个问题,互联网上比比皆是。而答案大同小异:看书、同行评审、参与开源项目等等。但是,关于如何检测自己是不是真的进步了这个问题,却一直悬而未决。

  我经常鼓励我的同行说,对于自己写的代码,无论是什么语言什么项目都应该不遗余力地尽可能长时间地保存下来,放到安全的地方(即 GIT/ SVN)。几年过去之后,再拿出来翻一翻。回过头来看自己的代码,会有一种神奇的喜剧效果,“OMG,这么狗屎的代码居然是我写的!!”,但是相信我,没 有比重新纠正这些项目和游戏代码更有成就感的了。

  上周末我在整理我七年前保存的一堆 Ruby 源文件时,发现了这个文件:fizzbuzz.rb。尽管曾经的我对此不屑一顾,但是现在,我,顿时心花怒放、兴高采烈:

# I am part of the chosen 1/200th!!!! # http://blog.codinghorror.com/fizzbuzz-the-programmers-stairwa y-to-heaven/ (1..100) .each{|i| if i % 3 == 0 && i % 5 == 0          print 'FizzBuzz'     elsif i % 3 == 0          print 'Fizz'     elsif i % 5 == 0          print 'Buzz' else print i      end  }

  $ ruby fizzbuzz.rb

12Fizz4BuzzFizz78FizzBuzz11Fizz1314FizzBuzz1617Fizz19BuzzFizz22  23FizzBuzz26Fizz2829FizzBuzz3132Fizz34BuzzFizz3738FizzBuzz41Fiz  z4344FizzBuzz4647Fizz49BuzzFizz5253FizzBuzz56Fizz5859FizzBuzz61  62Fizz64BuzzFizz6768FizzBuzz71Fizz7374FizzBuzz7677Fizz79BuzzFiz  z8283FizzBuzz86Fizz8889FizzBuzz9192Fizz94BuzzFizz9798FizzBuzz

  狗屎的时刻来了,看着这些代码,我竟然给自己点了几个赞:

  • 幸亏我写了点注释,我记起来了,我是在 2007 年 2 月的时候,看了 Jeff Atwood 的书之后,突发奇思妙想写了这段代码。我可真有先见之明。
  • 这段代码结果很正确。
  • 可读性真 TM 高,嘿嘿。

  不过,我可没有盲目地沾沾自喜。看着这些代码,我有了一些新的想法:

  • if 条件语句得重写,这样能提高可读性。
  • 数学模型执行了两次。
  • 由于代码里面的1、100、3、5 这些诡异的数字,使得想要在文本中做点改动变得很难。
  • 无法测试。

  几分钟之后,我知道该如何改进了。以条件语句为例:

  Ruby 语言允许我们将 if 放在代码块后面,更易于阅读。所以,我们可以稍微精简一点代码空间:

# I am part of the chosen 1/200th!!!! # http://blog.codinghorror.com/fizzbuzz-the-programmers-stairwa y-to-heaven/ (1..100) .each{|i| print 'Fizz' if i % 3 == 0      print 'Buzz' if i % 5 == 0      print i if i % 3 > 0 && i % 5 > 0  }

  然后我开始好好写 FizzBuzz 文件的新版本,希望下一个 7 年后能再次看到它。

  只有当我们回过头去看看曾经写的代码,我们才会真正明白自己取得了多么大的进步。这种创新自我的学习方式,常常会带给你美好的回忆。就在一个月 以前,我找出了我 10 年前,还在读大学的时候,创作的一个游戏。尽管里面有很多 bug,但是因为编程水平的提高,我很快就完善成功。

  曾经的代码代表了曾经的我们,蕴含了曾经的我们是如何艰辛创作的历程,展现了我们的缺陷,我们的优势,我们的发展和进步。它们能敦促你对其他程 序员时刻保持谦虚和耐心。这是你在这个计算机世界的进化史,宝贵无比。所以,请务必好好保存你写的所有代码。它们是你的孩子,是你的骄傲。

  译文链接:http://www.codeceo.com/article/look-your-old-code.html
  翻译作者:码农网 – 小峰