设为首页收藏本站

爱吱声

 找回密码
 注册
搜索
查看: 4310|回复: 3
打印 上一主题 下一主题

[科普知识] Bill Gates 的一次Review

  [复制链接]
  • TA的每日心情

    2024-2-11 13:31
  • 签到天数: 141 天

    [LV.7]分神

    跳转到指定楼层
    楼主
    发表于 2011-10-5 17:10:22 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    注:这是我很早以前从Joel Spolsky的一篇文章翻译的。原文出处http://www.joelonsoftware.com/oldnews/pages/June2006.html, S' W2 s8 f' z) D9 C( a% d) k: u
    ! o3 e; x" ]# B; \% u8 f
    Joel曾在以色列伞兵部队服役,后来在微软做程序经理,现在在纽约开了一家自己的软件公司。非常有名的程序员问答网站stackoverflow.com的创始人之一。他在大学里面专修过写作,经常在他的网站上发表一些关于创业和软件开发的文章,在软件界非常著名。

    ! M) `: L4 ]' A, S. B* O$ g& R8 E1 K( y, j4 W, Q5 e, R  Y
    Excel曾自带了一个非常糟糕的程序语言,当时这个语言还没有名字。我们称其为"Excel Macros".它没有变量、局部变量、子函数这些概念,几乎完全无用。虽然它有是还一些高级功能,比如“Goto”。% f' ~! s7 H/ s8 q1 P

    $ ?. b; P, x* }! [6 Q它存在的唯一理由是:它看上去要比Lotus的宏要合理一些。Lotus的宏不过就是记录了一组键盘敲击的顺序,用来在单元格中输入长字符串。; l3 q9 w$ N) @/ n. }2 c: y
    1 U& b) p6 z9 `' n# O, z) C
    1991年6月17日,我开始为微软的Excel团队工作。我的头衔是“程序经理”(相当于写需求分析的),我的任务是为Excel Macro 找到一个合适的改进方案。有人建议我可以用Basic来做这个方案。, z1 G  n/ W8 d. f/ \8 v: ]
    ) Q4 C! z$ m. ]  j6 h
    Basic?!
    9 {; p9 l2 f# |( d0 S  x9 f% ~& x
    我花了些时间和不同的开发团队商量。那时候Visual Basic 1.0 才刚刚推出,它简直是酷毙了!但在微软内部当时还有另外一个面临失败的项目"MacroMan".  他们试图开发另一种面向对象的Basic。这个团队好不容易才被告知他们的产品终于有了一个客户,就是我们Excel组. 当时他们的市场经理是Bob Wyman,是的,就是那个Bob Wyman(是谁?很有名吗)。可怜的Bob Wyan,我是唯一一个可以让他发挥推销才能的人。8 z( }; |1 S+ [- [- x: m" S6 R
    # {! ?  G# q* `4 Z; C/ r% `% j
    如我上述,MacroMan快失败了,虽然它有一些支持者,但最后还是面临被停掉。Excel团队确信他们这个Basic团队正是我们开发Visual Basic For Excel  所需要的。 我在这个项目的基础上试图再加入4个我喜欢的功能。Variant--一个通用的数据类型,可以随时保存其他类型的值。因为如果不这样的话,你必须先要定义一个转换声明才能保存单元格的值。后期绑定,也就是后来赫赫有名的IDispatch.另外两个特性是For Each语句(从csh中偷的)和With语句(从Pascal中偷的)5 i: z  [. X2 ]5 u$ \6 e
    * U4 E$ v! q/ `1 S8 d0 `
    接下来我开始写Excel Basic的规格说明,它真是他妈的工程浩大,我想完成时大概有500页吧。(“瀑布模型?”(传统软件开发模式),也许你正在窃笑。是的,但是请你闭嘴)4 |% Z" X7 R  k- D$ L  C
    ( ?2 C* @$ l  Y! c
    那时我们常常请Bill Gates作些review。基本上每个重要的特性Bill都得过一遍。我被告知把我的规格说明送到他办公室去,以便让他在review前做好准备。这个说明用了整整500页打印纸。
    0 G) f* X( G$ C$ l/ N+ L
    0 G5 w  p# b* n我把说明打出来送到了他的办公室后,正好当天还有一点时间,于是我试图评估一下Basic的日期和时间函数是否能处理所有Excel的功能。& d! Q5 r- F/ a0 k- m

    6 ?6 s( ]7 b2 H7 W& l6 @在大多数现代程序开发环境中,日期被存为real数值。整数部分是从过去某天算起的天数。比如说Excel中,以1900年1月1日为1算起,今天2006年6月16日就是38884。* t: W5 c+ E, d! f4 W$ X$ v! C

      c  E8 c- M! |- M我开始把Visual Basic 中的日期和时间函数和Excel中的都过一遍,看看是不是都能对应。我注意到Visual Basic文档中有一个很奇怪的声明:Basic 使用1899年12月31日而非1900年1月1日作为日期的原点,但不知什么原因,Excel中今天的日期值居然和Basic的一摸一样。
    ; u2 T+ Y6 ?3 U, S2 O' S! s, h# L8 c
    , I; i! a1 j4 v9 X8 E出问题了!( Y  j/ i- v# R! O! j$ v

    9 h5 O$ E% R6 c& M$ ]- W% U我跑到Excel资深程序员Ed Fries的面前.我想他应该知道为什么。" K3 V1 S/ c2 w
    “哦”,他告诉我:“看看1900年2月28日”. q6 D7 x3 U( {9 z4 Y* B
    “59”,我说0 M# A9 u& @! e% u" C3 `7 x
    “现在再看3月1号”
    % d" _4 q1 E9 u8 I7 z“61”。
    , [4 G  H/ ^* H8 R“60哪里去了”Ed问道/ c" O) M# i9 X+ B' P
    “2月29?1900是闰年!它可以被4整除”! k  ?0 `; R4 r9 r: ^6 P6 S8 S
    “很好的猜想,但不对”,Ed边说边走,留下我一个人在那里深思。
    8 T6 d& ^. L$ d3 T& H* H# P我又做了一些研究。发现可被100整除的年份不一定是闰年,除非它能被400整除。1 ~- Q' r( Z4 X8 m
    原来1900不是闰年。
    2 h6 L. u% j. v  t' u1 v( s  P& y“找到了,这是Excel的Bug”.我欢呼起来。
    # F) K* Q/ h( A' k“错”,Ed说,"我们这样做是为了能导入Lotus 123(另外一种电子表格)的数据"。
    . L+ ?8 u1 a  ]% b! {. A2 U  p2 F“那它是Lotus 123的Bug?”; j5 I+ _& f6 j+ D4 _
    "正确,但很有可能是故意的。Lotus必须适应640K的内存。但当时并没有那么多的内存,如果你忽略1900,你就可以根据一年的尾数是不是00来判断那年是不是闰年。这样做非常简捷方便。Lotus的小伙子们可能认为历史上两个月误差1天并不是很严重。而Basic团队看上去想给这两个月擦屁股,因此他们又把时间原点调回来了"
    % M8 x! V1 n& g8 A, `" D3 f! o% c& O. ]9 t6 m1 c$ N
    “啊!”我恍然大悟,然后开始继续研究为什么那里还有一个设置1904为时间原点的复选框。# {# L- R5 m1 E
    & j7 \! V% f1 h& x( c; t
    Bill做review的那天来临了。
    8 f  A) m6 j7 p+ H: `7 M) d7 w' f" _! _
    那是1992年6月30日。
    4 ?- ?9 y( m7 W: \+ P- Q
    ( S) l; P6 O! R& p- C, n. M那时候MS还没有现在这么官僚化。我对Mike Conte,Mike Conte对Chris Graham,Chris Graham对Pet Higgins,Pet Higgins对Mike Maples,Mie Maples最终对Bill.自底向上大约有6级,而非现在的11级或12级。 我们和使用8层管理结构通用汽车一样,是个充满乐趣的公司。" D. V0 O. J& W% K, p

    & p! y3 E8 k$ Q  u4 T0 j- b在Bill的review中,每一层负责报告的人都出席了,顺便带来他们的堂兄堂弟,表姊表妹,大姨小姑,还有一个专门记录Bill会上会说多少个“靠”的人。当然“靠”越少,结果就越好。
    8 I* N$ W# @. ?% g$ {* T4 `; b; \; F3 F
    Bill进来了。
    9 v1 {4 I. g& \& P6 |7 K2 J; H/ B- N! N
    他居然是两手两脚,一个脑袋.....看上去象个正常的人类。
    ) Q# ?+ A" I2 y( {/ I
      j8 ]9 A# ~' D4 t( W他手里拿着我写的文稿。% G$ m/ J' z# ?4 D

    0 y: e/ y+ d7 Z* p$ @/ g: {3 j4 i  e他手里拿着我写的文稿!
    $ W: v# R$ m; D* c6 v: h: s$ o0 y8 B+ a0 A2 Y
    他坐下来和旁边的人开了个对我而言毫无意义的玩笑,有几个人在窃笑。5 C& P" k$ }1 m( J* ^2 b6 k

    ( L, j; y# q# k! W$ x! {% gBill转向我了。6 `; y3 k- U  P: g% {" h9 K

    0 j8 R" Q  E8 u; B0 z. y  v  O1 t我注意到在我的说明空白处写着一些注解。他读过第一页!(激动)
    $ p" T% j( Y% ~8 z2 q, |, N; Y, b4 w; E3 N0 p& X
    他已经读过第一页并写下了他的笔记!(更激动)
    9 Z8 _+ a' G! C9 }1 V4 u( J! b: h4 I2 M( V  l, O* n% X0 B+ t
    因为从提交文稿到他手上不过一天时间,他一定在昨晚之前就读过。
      X3 E) v" @& S( |( L8 s% R8 B
    % d* k: L0 F. x( v我们开始一问一答。问题相当简单,但现在我已经记不清了,因为当时我一直在注意着他翻我的文稿...
    5 m, v* n+ k! A6 m4 M' H# K
    3 A1 a6 I" H  k: a. u2 O5 z他在翻我的文稿!!!(冷静,冷静,你可不是小姑娘了)
    ' J3 V7 U5 F5 K  u$ @7 t6 t, g/ h  d
    , Y6 ?1 m# {. `3 X! P# A  ...我看到每页空白都写满了注解,他妈的,他居然全部读完了,还写了注解。
    / v2 a% k0 D& l/ h$ g1 a, e0 j* H& z) T; P
    他居然全部读完了!
    8 }, @- Y, Q3 V" s2 N7 n5 e  d) u
    : ?0 C0 _" x. ?+ p1 H& C问题开始变得越来越难,越来越细。
    " `# U0 \  F  R+ M. |
    " a5 o9 S4 y3 l# j  e5 \提问有些随机。过去我常常认为Bill是我的大爷,事实上他是一个真正的好淫!他读了我的说明,他的问题可能正记在说明的空白处。以后我一定要把这些问题都在Bug跟踪系统中标记出来。) H% j/ I1 P$ e

    2 m/ f5 T4 ^7 H! _' E) ~终于最难的问题来了。
    2 n7 m; w0 W  j7 r7 l! T8 N
    " _% B9 k. A" ^! T; M! m7 J8 Y “我不知道,小伙子们”,Bill说,“有人研究过这个细节没有,比如说这些日期和时间函数。Excel有很多日期时间函数,在Basic中是不是能一一对应,他们工作方式是不是都一样的?”+ P2 [3 R, x* o  q2 B  K

    ; Z( j$ L/ B, h! q1 | “当然”,我说,“除了1900年的1月和2月”。% B. ~/ `& q# E( s* q

    : v& z% S/ |. G: n* z% q9 B+ x 沉默。
    0 v; D( Z# G% h9 o- e+ F8 G  K9 ]5 p! f1 _8 P7 R0 \0 }
    “靠”的记录人员和我老板惊讶的对视一眼。这家伙怎么知道的?1月,2月是什么东西?
    9 i1 z, \# V1 r& D, i, j; S# i1 b
    5 g! ?* D. N& C2 ?! `“OK,很好”,Bill拿起我的说明。
    : m9 m4 O# S( A) s9 b- m0 V# \1 I; D
      ....等等!我想知道......( b  y% A3 z* {8 O3 `% O. ^) U3 G/ u( z

    ; K8 I8 R. ^6 u6 i/ {  他们离开了。
    4 {/ x- Q; @' g$ Z9 Q2 J2 h  O7 e8 A; [
      “4个”,“靠”的记录者宣布,"这是我有生以来记得最少的一次。也许Bill开始步入中年了"。如你所知,Bill当年36。8 g$ b- M; D/ {  Z. R# X6 i6 v
    9 @4 }: E  _7 s6 S5 i' G$ J* m5 o
    后来我对这次Review终于有了一个解释,"Bill并没想真的想要review我的说明,他只是想确定一切是否在我控制之中。他的标准方式是问得越来越难,越来越难,直到你承认你不知道,然后,他就会提醒你你尚未准备好。如果我答起了他最刁钻的问题,没有人会确定会发生什么,因为这以前就没发生过。"% Q" A/ X2 `+ p; V8 o- ]. N! O5 W9 l

    - z& ?8 t+ R) s8 ] “如果是Jim Manzi在review上会怎么表现?”有人问道,“Manzi会反问,‘什么是日期函数???’”(Jim Manzi就是把Lotus带垮的MBA)
      V" Z2 s9 L: h/ S1 M- _( V
    " A/ f8 _* W3 g正确。
    . c0 y2 `/ B4 f% u- Q
      C5 X" X" n  [7 P9 p Bill Gates是个令人吃惊的技术狂热者,他理解Variants,Com对象,和IDispatch,知道为什么自动化和vtable不一样,也知道这个区别会导致双接口。他担心日期函数,如果不是他信任的人在开发,他会难以入眠。你可以对此嗤之以鼻,但他确实是一个程序员,一个真实的,地地道道的程序员。不是程序员的人去运作一个软件公司就像不会滑板的人跑去冲浪一样。“得了,我有非常棒的顾问在岸边指导我”,他们会一边说一边一次次从滑板上掉下去。那些标准MBA就是相信管理是通用函数。鲍尔默会成为另外一个John Sculley吗?John Sculley曾差点把苹果公司搞垮,只因为董事会相信他卖百事的经历会对运作计算机公司有所帮助。MBA的迷信者通常相信这一点:你可以让组织做你完全不懂的事。
    5 x1 W) l0 q9 ]' O: R; U! r8 R+ E7 d4 b# b2 [# \
    过去数年,微软变大了,Bill的管理范围过度扩展,他不得不投入更多精力去和US政府打交道。Steve坐上了理论上的CEO这个位置,这可以让Bill花更多的时间做他最擅长的--领导软件开发,但这并不能克服11级管理层带来的问题。它导致无休无止的会议,顽固地不管如何也要创建每种产品的倾向,(微软在研发、官司、公司声誉上损失了多少亿美元,只因为决定开发一个Web浏览器,还让它免费。),还有就是过滥的招聘让微软正逐渐失去中层人员中的精英。(Douglas Coupland在Microserf*中写道:”在1992一年中他们雇佣3100人,你知道并非所有人都是珍珠“)
    " C( b% p& d) o6 O
    $ E2 D7 E: H2 z- t- J对了,派对已经搬家了。Excel Basic变成了Microsoft Visual Basic for Appliation for Microsoft Excel,这个名字里面的注册商标符号太多,以至于我都不知道应该把他们放在哪里。我于1994年离开了微软,想来Bill已经完全忘记了我。直到有一天我读到华尔街日报对BillGates的一次采访,他提到在过去,象招募一个Excel的程序经理的事情是多么困难,因为他们并非象苹果长在树上那样垂手可得。
    $ G5 h# S  F' u0 Y0 s$ q& `7 l2 \# B+ M& W; b5 C8 X0 l3 j
    他是谈我吗?或许应该是别人了吧。
  • TA的每日心情

    2019-3-13 15:27
  • 签到天数: 106 天

    [LV.6]出窍

    沙发
    发表于 2011-10-6 13:14:26 | 只看该作者
    翻译得很到位!& y9 F2 ~8 C8 O: _2 @# j

    该用户从未签到

    板凳
    发表于 2011-11-5 21:20:10 | 只看该作者
    呵呵,不错呀...........
  • TA的每日心情
    开心
    2024-9-18 07:01
  • 签到天数: 1014 天

    [LV.10]大乘

    地板
    发表于 2011-11-22 16:43:14 | 只看该作者
    真好看 BILLGATES的成功(我指天生的程序员如何创立一个超级公司这部分)绝非偶然啊  z1 A/ V1 H5 H) k' K% \0 ?2 c
    以色列能击垮貌似庞大的阿拉伯 靠的真是深入探究每一个可能的问题啊6 ^" v" P0 D8 ?3 Y# w0 J: s
    我们还有多远?

    手机版|小黑屋|Archiver|网站错误报告|爱吱声   

    GMT+8, 2025-12-15 19:30 , Processed in 0.028718 second(s), 17 queries , Gzip On.

    Powered by Discuz! X3.2

    © 2001-2013 Comsenz Inc.

    快速回复 返回顶部 返回列表