[转载]程式设计之道 (THE DAO OF PROGRAMMING)
转载自: 网络邮件
第一部 寂静虚无篇
大师如是说:"学会从程式抓虫子之后, 就可以毕业了"
1.1 节
- 寂静虚无中有奥秘, 不动不静, 乃程式之源, 吾无以名之, 故称之为程式设计之道.
- 若道至大, 则作业系统至大; 若作业系统至大, 编译程式亦然; 若编译程式至大, 则应用程式亦复如是, 是故使用人大悦, 世有和谐存焉.
1.2 节
- 程式设计之道无远弗届, 虽晨曦微风而返.
- 道生机器语言, 机器语言生组译程式.
- 组译程式生编译程式, 于是万余语言存焉.
- 各语言有其目的, 均表达软件之阴阳; 其在道中亦各得其所.
- 但若能避免, 就不要用COBOL 写程式.
1.3 节
- 太初有道, 道生时空, 故时空乃程式设计之阴阳.
- 程式员不悟道则时空永不敷使用, 悟道者恒有充份时空完成目标.
1.4 节
- 上智程式员闻道而行之, 中智程式员闻道而求之, 下智程式员闻道而笑之.
- 若无笑声则无道矣.
- 至高之声难以听闻.
- 前进就是后退之路; 大智总是晚成; 每一个完美的程式仍有BUG.
- 道在所有知识之外.
第二部 古之大师篇
大师如是说:"三日不写程式则生命无趣."
2.1 节
- 古程式员神秘而深奥, 无以度量其思维, 仅能描述其表象.
- 像狐狸涉水般地小心; 像战场老兵般地警觉; 像未经琢磨的木头般地璞拙; 像洞中深潭地不透明.
- 谁能指出他们心灵中的秘密?
- 答案全在道中.
2.2 节
- 大师Turing曾经梦到他是一部电脑, 醒后道:
- "不知是我Turing作梦变成机器, 还是一部机器作梦变成我我Turing."
- 一家大电脑公司的程式员参加软件会议后, 向他的经理报告说:"你知道其他电脑公司有什么程式员吗? 他们不修边幅, 头发长而邋遢, 衣服既旧且皱, 他们破坏了气氛, 而且我简报时老是制造噪音."
- 经理说:"我根本就不应该派你参加会议, 这些程式员超然物外, 他们把生命看成无稽, 意外的结合. 他们往来而无藩篱, 为他们的程式而活, 为什们他们一定要受社会积习的约束?
- 他们生活在道中.
2.3 节
- 生手问大师:"有一个程式员从不设计, 测试程式, 写作文献, 但了解他的人都认为他是世间最好的程式员. 为什么?"
- 大师曰:"这个程式员已充份悟道, 他超越了设计的需要; 系统垮了不会生气, 而无条件接受这个世界. 他超越了文献的需要, 他不再计较是否有人看他的程式. 他也超越了测试的需要, 他的每一个程式都圆满无缺, 清澈, 优雅, 目的自明.
- 是的, 他已悟道, 登堂入室.
第三部 设计篇
大师说:"到测试程式时再回头修改设计就太迟了."
3.1 节
- 曾经有人在参观电脑展每天进门时都向警卫说:"我是的妙贼, 偷东西的技巧已臻化境, 先告诉你, 我绝不会放过这次展览."
- 这段话刺激到警卫, 因为展览场有好几百万元价值的仪器, 所以老是盯这他, 不过却只看到这个人一个摊位接着一个摊位看, 哼著小曲而已.
- 这个人出门的时侯, 警卫把他带到一旁搜身, 但却找不到什么.
- 第二天这个人又来了, 而且教训警卫说:"昨天我收获不错, 不过今天会更佳." 所以警卫就更加注意他了, 但是仍然没有结果.
- 最后一天警卫终于忍不住好奇心, 问那个人:"贼大师, 我给您弄得寝食难安, 您是否以教我, 究竟偷了些什么?"
- 这个人笑笑, 说:"我偷的是概念."
3.2 节
- 从前有一位大师专写没有结构化的程式, 一个生手模仿他, 也开始写没有结构化的程式. 当这位生手要求大师评量进展时, 大师却批评他写作没有结构化的程式.
- 大师说:"对大师适用的不一定适合生手, 在能超越结构化之前, 必须先悟道."
3.3 节
- 某长官问程式员:"设计会计系统与作业系统, 那一个比较简单?"
- 程式员说:"作业系统."
- 长官发出不相信的惊呼:"很显然的, 会计系统不如作业系统复杂",他说.
- "不!"程式员回答,"在设计会计系统时, 程式员是各种不同主意的人之间的桥梁, 这些主意不外乎: 系统要如何作业? 报表型式如何? 要如何迎合税法?...等等. 反过来, 作业系统却不受外界表象的限制; 在设计作业系统时, 程式员寻求人与机器间最纯的和谐, 这就是为什么作业系统容易设计."
- 长官点头微笑称是:"但是那一个容易侦错?"
- 程式员没有回答.
3.4 节
- 经理去见大师, 并且告诉他一套新应用程式文件的需求规格, 问道:"如果我给你五个程式员, 要多久才能设计好这个系统?"
- 大师很快回答:"一年."
- "但是我们需要马上用这个系统! 如果我给你十个程式员, 那要多久?"经理说.
- 大师皱眉说:"这要两年."
- "如果我给你一百个程式员呢?"
- 大师耸耸肩:"这个系统根本作不出来了."
第四部 写作篇
大师如是说:"写作良好的程式本身自成天堂, 写得差的程式本身就是地狱.
4.1 节
- 程式要轻灵, 副程式像一串珍珠. 程式的精神与意图应始终如一, 不多不少; 没有多余的循环, 也没有额外的变量, 既不缺少结构, 也不过份笨重.
- 程式应该追随" 最低惊讶定律",这是什么?
- 简单得很, 使用人对程式的反应是惊讶的机会要愈低愈好.
- 程式不管再复杂, 应该以一个整体来作用; 他应该用内部逻辑, 而不是外在的表象来指导作业.
- 如果程式不满足这些要求, 就会杂乱而易生混淆, 唯一的补救就是重新写过.
4.2 节
- 生手问大师:"我有一个程式, 有时侯作得很好, 有时侯却不行; 我一直遵行程式设计的规律, 但是却把我弄得很困扰, 其理安在?"
- 大师答曰:"因为不悟道才会如此, 只有笨蛋才会期望他的同侪有合理的行为, 而你却对人类生产的机器有所期望?!计算机只模拟了决定论, 只有道才十全十美.
- 程式设计的准则还是暂时性的, 只有道才会进入永恒. 所以, 你在开窍前要先思索道."
- "但我要如何才能知道已经开窍了呢?"生手问.
- 大师回答:"从此以后, 你的程式都能正确执行."
4.3 节
- 大师对弟子说:"不论软件之为大为小, 道在所有软件中."
- "桌上型计算机有道吗?"弟子问.
- "有!"大师答.
- "电动玩具程式中有道吗?"弟子续问.
- "也有!"大师说.
- "那个人电脑的DOS 中有道吗?"
- 大师咳一下, 轻轻挪动了位置,"下课",他说.
4.4 节
- 皇太子的程式员正在写作软件, 指尖在键盘上飞舞, 程式顺畅无误的编译完成, 执行起来像阵微风轻拂而完美的结束.
- "了不起!", 太子叹曰:"你的技巧无懈可击."
- "技巧?"程式员从终端机上转过头说,"我所信从的是道, 道超越任何技巧! 我开始学写程式时, 在我眼前所见是混成一片的程式; 三年后, 不再见到这一大片程式了, 我学会使用副程式; 现在, 眼前一片空灵, 什么都没有了, 所有东西都进入无型式的一片静寂; 所有感觉都不必作用.
- 我的精神可以依直觉而不必依任何计划行事, 换言之, 我的程式自己写作自己. 当然, 有时会有困难的问题; 我看着他们到来, 我降低自已的速度, 静静的看, 改一列程式之后困难就会烟消云散; 我再重新静静坐着欣赏工作的欢乐. 我闭上双眼一会儿, 然后关机."
- 皇太子说:"我的所有程式员都那么聪明睿智吗?"
第五部 维护篇
大师如是说:"虽然程式只有三列, 但总有一天需要维护."
5.1 节
- 常用的门不必上油.
- 急流不会淤塞.
- 声音与思想不能在真空中传递.
- 不用的软件会生锈.
- 这就是至大的奥秘.
5.2 节
- 经理问程式员究竟要多久才能把手上的程式写完."明天",程式员很快的回答.
- 经理说:"我想你不太踏实; 真的要多久?"
- 程式员想了一会儿:"我希望在程式中加上一些东西, 这至少要两周."程式员终于说
- "时间还是短了一些", 经理坚持说:"如果你能简单的告诉我什么时后能写完我才会满意."
- 程式员同意这一点.
- 几年后经理退休了, 在欢送餐会上发现那个程式员伏在终端机上睡着了, 因为他写程式写了整夜.
5.3 节
- 一个生手被分派去写一个单纯的财务软件.
- 这个生手狂热地工做了几天, 但是当大师看他的成品时, 却发现这个程式中包含一个萤光幕编修程式, 一组一般性的绘图程式, 一个人工智能界面, 但却没有什么与财务方面有关.
- 大师就问他, 这个生手却变得很激动:"不要那么没耐心,"他说, "我最终会把财务部份加上去."
5.4 节
- 好农夫会忽视他种的谷子吗?
- 好老师会忽略他最差的学生吗?
- 好父亲会容许他的孩子挨饿吗?
- 好程式员会拒绝维护自己的程式吗?
第六部 管理篇
大师如是说:"程式员要多, 经理要少, 生产力就会增加."
6.1 节
- 经理有开不完的会的话, 程式员就会写电玩; 主计部门想到利润, 发展经费就会被删减; 高级科学家谈到蓝蓝青天, 那么青天一定会有浮云飞过.
- 当然, 这不是程式设计之道.
- 当经理许下承诺, 程式员就不理会电玩; 当主计部门有长程规划, 就会回复和谐与秩序; 当高级科学家处理手上的问题, 问题很快就会解决.
- 这才是程式设计之道.
6.2 节
- 为什么程式员没有生产力? 因为他们的时间都花在开会上头.
- 为什么程式员难以驾御? 因为管理阶层干预太多.
- 为什么程式员一个接一个辞职? 因为他们精力耗光了.
- 在不良管理下工作, 程式员不会觉得他的工作有价值.
6.3 节
- 某个经理快被炒鱿鱼了, 但是他底下的一个程式员写了一个叫好又叫座的程式; 当然, 这位经理因而保住了饭碗.
- 经理打算给这位程式员一点奖励, 但他拒绝接受, 并且说:"因为我觉得这是个有趣的概念, 才会写这个程式, 所以我不希望有奖励."
- 经理听了之后说:"这个程式员虽然职位不高, 但却充份了解做为一个职员的责任, 让我们把他升成崇高的管理顾问吧!"
- 在告诉程式员时, 他再度拒绝, 说:"我之存在是因为可以写程式, 如果升了我, 那除了浪费每一个人的时间外而成不了事. 我可以走了吗? 我还得写程式."
6.4 节
- 经理告诉程式员们说:"下面是你们的工作时间: 早上九点来上班, 下午五点钟下班." 所有程式员都很生气, 有几个马上辞职.
- 于是经理说:"好吧! 这样好了, 只要能够如期完工, 工作时间由你们自定."程式员现在满意了, 每天中午开始工作, 直到第二天早上.
第七部 公司智慧篇
大师如是说:"你可以对主管示范一个程式, 但无法让他通晓电脑."
7.1 节
- 生手问大师:"遥远东方有一个叫" 公司总部" 的伟大树状结构, 上面满满地标上了些副总裁, 会计长等的图案. 它发出大量的备忘录, 每张上面都写了" 收文!" " 发文!"没有人知道是什么意义. 每年都会把新的名字加到新的分 枝上, 但似乎全都徒劳无功. 为什么这样一个不自然的组织还能继续存在?"
- 大师回答说:"你已经体认到这个庞大的结构, 而被它不合理的目的困扰. 不过你能不从它无休止的回旋而得到乐趣吗? 能够不欣赏深藏在枝叶底端毫无困难的程式设计吗? 为什么要被他的无用而困扰呢."
7.2 节
- 东方海上有大鱼曰鲲, 鲲能变成双翼遮天的大鹏. 当大鹏飞越陆地时带来一道公司总部的讯息, 这道讯息正好掉在一群程式员中央, 然后大鹏折起双翼乘风而归.
- 生手程式员瞪眼望着大鹏, 因为他们不认得; 中智程式员忧大鹏的来临, 因为他们害怕它带来的讯息; 只有大师才能继续坐在终端机前工作, 因为他不知大鹏的来去
7.3 节
- 象牙塔的魔术师带着他的最新发明去见大师, 他推了一个大黑盒子走进大师的办公室, 大师正在静静的等著.
- "这是一套整合性, 分布式, 一般用途的工作站",魔术师如是说,"还有一套专属的作业系统, 第六代语言, 多项最先进的使用人界面, 再加上人体工学的设计; 这花了我的助手们好几百人年才造出来的, 不是很了不起吗?"
- 大师抬了下眼珠子,"的确了不起."大师说.
- 魔术师继续说:"公司总部已经下令每个人都要用这台工作站做发展新软件的基石, 您同意吗?"
- "当然."大师答道:"我马上会把它放到资讯中心去."于是魔术师高高兴兴的回到象牙塔去.
- 几天后, 一个生手在大师的办公室里团团转, 说:"我找不到新程式的报表, 您知道会在那儿吗?"
- "当然",大师答道,"报表就堆在资讯中心里头的基石上!"
7.4 节
- 大师可以毫无忧虑的从这个程式转入另一个程式, 管理上的改变伤不到他; 纵使计划中止了, 也不会被炒鱿鱼. 为什么? 因为他充满了道.
第八部 硬件与软件篇
大师如是说:"没有风, 草不会动, 没有软件, 硬件就是废物."
8.1 节
- 生手问大师:"我知道一家电脑公司比其他的大得多, 高高在上就像巨人之比侏儒; 它的任一部都可以单独成为一个企业. 为什么会这样?"
- 大师回答:"你为什么问这个笨问题? 这家公司就是因为它大才会这么大. 如果它只知道硬件, 没有人会买它; 如果只生产软件, 没有人会用它; 如果只维护系统, 人家会把它看成修理员; 但是因为他把所有的合在一起, 人们就把它当神一样看待了
- 它根本无需竞争, 因为赢来不费吹灰之力."
8.2 节
- 大师有一天经过一个生手旁边, 发现生手迷上一台手掌型的电玩,"对不起",大师说, "我可以看看它吗?"
- 生手停下来, 并且把这台机器交给大师. 大师说:"我看到这台机器玩起来有三个层次: 初级, 中级, 高级; 不过这种机器通常都有另一个层次的说法, 使机器赢不了人类, 而人类也胜不了机器."
- "啊! 大师",生手说:"这个奇妙的开关在那里?"
- 大师把机器摔到地上, 用脚把它踏烂.
- 突然地, 生手开窍了.
8.3 节
- 从前有一位微电脑的程式员对一位来拜访他的大型电脑程式员说:"你看, 在我这儿多好! 我有我自己的作业系统与案储存设备, 我不必与任何人共用任何电脑资源;软件本身自给自足, 而且容易使用. 为什么你不辞掉目前的工作来加入我们?"
- 于是大型电脑的程式员就对他的朋友解释:"大型电脑就像古之圣哲般的稳稳座落在资讯中心中央, 磁盘一个接一个蔚为奇观, 软件像钻石般地有多种面目, 像古森林般的浓密茂盛. 各个程式像一片急流般地涌入系统, 而这就是我在那儿工作的乐趣 ."
- 听了这段话之后, 微电脑程式员静默无声; 但是这两个人却结为好友, 至死不渝.
8.4 节
- Hardware与Software走在路上, Software说:"你是阴我是阳, 如果我们能一条心, 一定会成大名赚大钱."所以,他们就联合在一起而想征服世界.
- 走了一段路之后, 碰到Firmware, 穿得破破烂烂, 拿着根柺杖, 并且对他们说: "道在阴阳之外, 寂静不动如古井之不生波澜; 道不求名, 故无人知晓其存在; 道不逐利, 因它圆满无缺. 道超乎时空之外."
- Hardware和Software听了之后倍感惭愧而打道回家.
第九部 尾声
大师如是说:"这是下课的时候了!"
No comments yet.