想写代码?离开你的电脑吧!

    最近我认识到一些事情。写代码的最好地方不是在电脑前用你的编译器、集成开发环境和各种工具来写。写代码最好是远离所有这些工具,去到你能够正确思考的地方。你相当熟悉一种语言了,你很容易就能把你心中的程序翻译成编译器可以编译(或解释器可以解释)的程序,不过,难就难在心中形成程序。
前几天我坐火车去旅行。我带了电脑,但没有网络。很不幸,我正要用一个商业编程语言(碰巧是IDL),为此我得用我们大学的网站许可。由于无法上网,我无法获得网站许可,这样我也就不能运行编译器和集成开发环境。虽然你喜欢商业编程语言,但它需要昂贵的许可,而它那时使我不能用编辑器写代码。那么……想想看是什么…… 到底是什么使我思考!

我从第一任老板那里学到的最好的一课就是:“如果你的代码无法如你期望的那样运行,不要用调试器(debugger),自己想。”

就是离开电脑后迫使你做的事情。人很容易陷入下列的思维模式:
写一些(相当差的)代码
编译和运行
用一个选择不当的测试案例来测试
发现它无法运行
做一些小改动,或许可能解决问题,
重复以上步骤……
当然这导致最后编写的很差,可能有很多问题,测试通不过。
离开电脑,迫使你充分调动你头脑里的想法,与用电脑编译和运行代码相比,那会花更多时间(至少对小程序来说是如此……)。因此你不需要做很多小改动和重新运行,你会认真思考代码在做什么。自从计算机A级考试以来,直到我前几天在火车上这样做的时候,我才第一次在纸上“运行”代码(就是说,写好每个变量的列,并在程序中计算出每个变量的值)。
就前几天写代码这个例子来说,我在一张纸上写出代码,思考所写的代码,逐步打出一些代码,思考更多,时间长了之后我就尝试用编辑器编辑,设法写出了一些质量高、快速并且无漏洞的代码。最后我把代码(一些涉及很多递归的区域增长图像分割代码)从纸上复制到我的集成开发环境中,第一次就编辑(只有一个句法错误——我永生难忘)并运行成功(而且完成了所有我在纸上设计的测试)。

作者: lsw1011   发布时间: 2011-06-29

不错不错。。。

作者: lsw1011   发布时间: 2011-06-29