b94902xxx 板


LINE

THE DAO OF PROGRAMMING Geoffrey James 程式设计之道 冼镜光 微电脑时代96,97 第一部 寂静虚无篇 大师如是说:"学会从程式抓虫子之後, 就可以毕业了 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 节 .从前有一位微电脑的程式员对一位来拜访他的大型电脑程式员说:"你看, 在我这儿多好! 我有我自己的作业系统与案储存设备, 我不必与任何人共用任 何电脑资源;软体本身自给自足, 而且容易使用. 为什麽你不辞掉目前的工作 来加入我们?" .於是大型电脑的程式员就对他的朋友解释:"大型电脑就像古之圣哲般的稳稳座落i 在资讯中心中央, 磁碟一个接一个蔚为奇观, 软体像钻石般地有多种面目, 像 古森林般的浓密茂盛. 各个程式像一片急流般地涌入系统, 而这就是我在那儿工 作的乐趣 ." .听了这段话之後, 微电脑程式员静默无声; 但是这两个人却结为好友, 至死不渝. 8.4 节 .Hardware与Software走在路上, Software说:"你是阴我是阳, 如果我们能一条心, 一定会成大名赚大钱."所以,他们就联合在一起而想征服世界. .走了一段路之後, 碰到Firmware, 穿得破破烂烂, 拿着根柺杖, 并且对他们说: "道在阴阳之外, 寂静不动如古井之不生波澜; 道不求名, 故无人知晓其存在; 道不逐利, 因它圆满无缺. 道超乎时空之外." .Hardware和Software听了之後倍感惭愧而打道回家. 第九部 尾声 大师如是说:"这是下课的时候了!" -- 网路上奇妙的文章... (因为某人的签名档) --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 219.87.129.146
1F:推 hamigwa:大推!! 11/09 23:04
2F:→ alex1025: 考完期中考再来看~囧~打逼好危险 11/09 23:10
3F:推 LittleCVR:有意思~ 11/09 23:22
4F:推 Sinze:有yeah教授的感觉@@ 11/09 23:33
5F:推 pcncvl:推庖丁解牛 XD 11/10 00:57







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Gossiping站内搜寻

TOP