移山之道

关注软件开发技术和管理的社区网站

欢迎光临 移山之道 登录 | 注册 | 帮助
in 搜索

关心

移山之道 作者

梦断代码 读后感(III)远虑和近忧

[part 3]

几个星期前,我给《现代软件工程》课的每一个团队都发了一本 《Dreaming In Code》的中文版 《梦断代码》,要求写读后感。这本书讲了这样的故事:一群很有经验的代码牛人在先进软件开发模式的指导下,没有资金压力,在更多大牛的带领下,原计划用一到两年的时间开发出一个备受期待的个人信息管理软件(PIM),后来花了七年时间才完成这一创举,但是已经无人喝彩。我是9月份读的英文版,后来又翻阅了中文版,也有一些感想如下。

Dreaming in Code: Two Dozen Programmers, Three Years, 4,732 Bugs, and One Quest for Transcendent Software

Kapor 的团队看起来非常重视“远景”, 他们似乎没有近忧 - 这也许是致命的。

他们对于软件的基本架构/infrastructure 非常关心,例如对于存储系统,它们提出了下列需求:[p103]

  1. it has to make life easy for the Python programmers
  2. it has to operate efficiently over a network
  3. it needs to be able to handle very large individual date items and very large numbers of items
  4. it has to be reliable, using database "transactions."
  5. it has to support searching and indexing
  6. [0] User experience  //Kapor 后来加上去的,似乎不相干的一条远景。

后来对于Data Storage,又有如下构想:[p109]

  1. Provide programmers with as revolutionary a data model as users
  2. data can live anywhere.
  3. Data is safe from corruption.
  4. Data is quick to get.
  5. Data can be large.

非常令人佩服的远虑。 如果一个项目能同时实现其中3个目标,就已经能实用并吸引客户,开始赚钱了。 但是Chandler 项目的同志们不满足于只实现两三个,他们要实现全部5个梦想。

一群牛人在 “没有近忧,只有远虑” 的条件下讨论问题,最后只能议而不决。 在一次次延续到深夜的讨论中,有人感慨 - "How is this night different from all other nights?" //[p110]

没有近忧,或者说不用为近忧而负责 - “我们这个月的目标没完成不要紧,但是我们的远景一定要讨论好”。 导致了项目不能收敛 - 一个项目的一个里程碑中,不确定的事情应该越来越少,bug 也越来越少,直到产品发布。

Making firm technical choices was hard in the absence of a settled design, and settling on a design was hard in the absence of a technical roadmap. [p150 - 151]

正因为大家没有近忧,所以大家可以继续等待,设计要等技术决定后才好做,而技术的选择要等设计决定后才好开始。就这样,大家折腾到2005年的时候,他们才从高瞻远睹的远虑的云端中下来,有了第一个脚踏实地的计划:

But for the first time, at least, they could see they had a plan grounded in reality, rooted in estimates that ... [p232]

Kapor 毕竟是聪明人,很多年以后,他说到了教训:

We've consistently overinvested in infrastructure and design... [p342]

收敛的另一个特点是 - 做过了的决定,就要执行,不要反复。事实上,Chandler 团队在很多决定上摇摆不定。 架构师Hertzfeld 度假回来,发现他带领其他同事奋战一个夏天得到的 Document Architecture 被扔到一边,原来 Kapor 决定 “We'll have to come back and realign things”  [p168]。 如果你是做义务劳动的 Hertzfeld,你还能做下去么?

回到 “远景”, 我相信几乎没有合适的解决方案能满足“远景” 中的所有要求,很难找到 “多快好省” 的解决方案(书中提到 fast|cheap|good 不能兼得,这也是MSF 中 time | resource | feature 三个元素的矛盾)。但是往往存在若干方案,从不同的角度逼近最优,但是有各自令人讨厌的缺点。我们能否有智慧来选择这样一个方案,把近忧,远虑都慢慢解决?

我自己在微软正在做一个创新项目,前几天一位加入这个项目不久的优秀的开发人员对我说,我们去年设计的数据库问题太多了,如果我们早就像我这样设计,估计会好很多。我不是数据库的专家,我只能对他说,如果我们当时坚持要做到今天这样才发布,这个项目也许就做不到今天了。

换句话说,正是因为早期那些不完美,但是及时的设计,让后来者有挑剔这些不完美的奢侈机会。

我们每个人在使用这些不完美的软件(Windows, Outlook, 甚至Linux)的时候,都应该感谢当初设计者做出了正确决定,而那些坚持完美设计远景的项目,它们都到哪去了?

已发表 2008年11月18日 1:34 作者 关心
归档在:

评论通知

如果您想在帖子更新时接到邮件通知,请先登录。这里

订阅帖子评论使用 RSS

评论

 

匿名人士 说:

”If there's anything to be learned is to never name a software project after a "Friends" character. “

十一月 18, 2008 17:56
 

小飞 说:

vision里没提到这个程序应该小巧、快速(user experience算是这个范畴吧),也难怪他们会用python来写这个桌面程序,他们是不是也犯了“手里有个新榔头,就把一切当钉子”的错误呢?

十一月 18, 2008 19:41
 

关心 说:

to 康德 -

the project wasn't named after that Friends character, anyway, it would be a pity if that's all you can learn from this project.

十一月 20, 2008 15:56
 

关心 说:

小飞 - 很多用户对Chandler 的第一感就是 - 启动太慢了。。。

十一月 20, 2008 16:11
 

小飞 说:

我下载了试用了下,启动速度比outlook慢多了,退出时也是,窗口上的控件都是一个个逐渐呈现的……而且匪夷所思的是居然还有个Debug菜单项,可以看到程序输出的一堆log信息

十一月 20, 2008 19:55
 

关心 说:

>匪夷所思的是居然还有个Debug菜单项,可以看到程序输出的一堆log信息

Chandler team expect you to debug it and fix bugs for them...

十一月 24, 2008 11:35
 

匿名人士 说:

又到了 拉出来遛遛 的时候了, 今年的 5个团队 要做这样的项目: 1) 觉得生活郁闷么?那就去 开坦克 吧。 2) 希望会非常实用的 剧团管理工具 ,他们组里有一位同学,原来说好了要负责一个关键部分,但是后来就是不写代码,怎么办?

十二月 16, 2008 0:43
 

匿名人士 说:

一月 23, 2009 11:24
 

匿名人士 说:

Apple或者可以当做一个反例,他们总是用很长的时间研发一个近乎完美的产品。

不过现在的苹果更新的速度明显比以前快了,从iphone,Apple App Store更新中可以看得出来。

我觉得梦断代码的例子恰恰告诉我们:。故不积跬步,无以至千里;不积小流,无以成江海。骐骥一跃,不能十步;驽马十驾,功在不舍。锲而舍之,朽木不折;锲而不舍,金石可镂。蚓无爪牙之利, 筋骨之强,上食埃土,下饮黄泉,用心一也。蟹六跪而二螯,非蛇之穴无可寄托者,用心躁也。

七月 18, 2009 11:45
 

匿名人士 说:

十二月 13, 2009 22:19

说说您的看法?

(必填) 
(可选)
(必填) validate code
(必填) 
发表

About 关心

邹欣 - 曾写: 《移山之道》,《编程之美》(合作) 。 在写: ppt, email。 想写: 《编程之美 - 实战中的设计》...

联合

Powered by Community Server (Personal Edition), by Telligent Systems
访问计数:     京ICP备06016978号
王屋村村民除了看yishan.cc, 还浏览下列网站.