第9章

好设计是解决主要问题的设计。厨房的煤气灶有四个出火口,排成一个正方形。每个出火口都由á一个ฐ调节器控制,四个出火口就有四个调节器。请问应该如何摆放调节器?最简单的摆放方法当然是把四个调节器排成一列,但要是这样做,人们使用起来就很不方แ便,每次都要停下来想一下到底每个ฐ调节器对应的是哪个出火口。如果直接把调节器排成与出火口一样的正方แ形,就不会有这个ฐ问题了。

好设计是解决主要问题的设计。厨房的煤气灶有四个出火口,排成一个正方形。每个出火口都由一个调节器控制,四个出火口就有四个调节器。请问应该如何摆放调节器?最简单的摆放方แ法当然是把四个调节器排成一列,但要是这样做,人们使用起来就很不方便,每次都要停下来想一下到底每个ฐ调节器对应的是哪个出火口。如果直接把调节器排成与出火口一样的正方形,就不会有这个问题๤了。

先,管理企业其实很简单,只要记住两点就可以了:做出用户喜欢的产品,保证开支小于收入。只要做到这两ä点,你就会过大多数创业公司。随着事业的展,你自己้就能琢磨出来其他的诀窍。

先,管理企业其实很简单,只要记住两点就可以了:做出用户喜欢的产品,保证开支小于收入。只要做到เ这两点,你就会过大多数创业公司。随着事业的展,你自己้就能ม琢磨出来其他的诀窍。

大多数的斗争,不管它们实际上争的是什么,都会以思想斗争的形式表现出来。1้6世纪的英国宗教改革englishreformation本质上是为了争夺权力和财富,但是却表现为ฦ英国人要求自主ว的精神与罗马教廷腐化的控制ๆ之间的斗ç争。思想斗争更容易争取支持者。不管哪一方获胜,他们所代表的思想也๣就被认为获得了胜利,仿佛上帝通过选择胜利ำ的一方表示了自己้的倾向。

大多数的斗争,不管它们实际上争的是什么,都会以思想斗争的形式表现出来。16๔世纪的英国宗教改革englishreformation本质上是为了争夺权力和财富,但是却表现为英国人要求自主的精神๰与罗马教廷腐化的控制之间的斗争。思想斗争更容易争取支持者。不管哪一方获胜,他们所代表的思想也就被认为获得了胜利,仿佛上帝通过选择胜利的一方表示了自己的倾向。

本书就是帮助你了解黑客、从而理解这个ฐ时代的一把钥匙。

本书就是帮助你了解黑客、从而理解这个时代的一把钥匙。

随大流的代价

使用一种不强大的语言,你的损失有多大?实际上有一些现成的数据可以说明这个问题。

衡量语言的编程能力的最简单方法可能就是看代码数量。所谓高级语言,就是能够更强大抽象能力的语言,从某种意义上,就像能够更大的砖头,所以砌墙的时候用到เ的砖头数量就变少了。因此,语言的编程能力越强大,写出来的程序就越短当然不是指字符数量,而是指独立的语法单位。

强大的编程语言如何让你写出更短的程序?一个技巧就是在语言允许的前提下使用“自下而上”bottom-ๅup的编程方法。你不是用基础语言ba色浪uage开应用程序,而是在基础语言之上先构建一种你自己的语言,然后再用后者开应用程序。这样写出来的代码会比直接用基础语言开出来的短得多。实际上,大多数压缩算法也๣是这样运作的。“自下而上”的编程往往也便于修改,因为许多时候你自己添加的中ณ间层根本不需要变化,你只需要修改前端逻辑就可以了。

代码的数量很重要,因为ฦ开一个程序所耗费的时间主要取决于程序的长度。对于同一个软件,如果用一种语言写出来的代码比用另一种语言长三倍,这意味着你开它耗费的时间也会多三倍。而且即使多雇人手,也๣无助于缩短开时间,因为当团队规模过某个ฐ门槛时,再增加人手只会带来净损失。fredooks在他的名着《人月神话》中ณ描述了这种现象,我的所见所闻印证了他的说法。

如果使用lisp语言,程序能变得多短?以lisp和c的比较为例,我听到的大多数说法是c代码的长度是lisp的7倍到1้0倍。但是最近,ne9arcນhitecນt杂志上有一篇介绍ita软件公司的文章

,里面说“1行lisp代码相当于20行c代码”,因为ฦ此文都是引用ita总裁é的话,所以我想这个ฐ数字来自ita的编程实践。如果真是这样,那ว么我们可以相信这句话。ita的软件不仅使用lisp语言,还同时大量使用c和c+ใ+,所以这是他们的经验之谈。

‘jenmuehlbຘauer,“or逼tz的新า突破”or逼tzrea9e9arcນhitect,2๐002年4๒月号。’

我认为,这种比例肯定不会是一个常数。如果你遇到更困难的问题๤,或者你雇到เ了更聪明的程序员,这个比例就会增大。一种出色的工ื具到เ了真正优秀的黑客手里,可以挥出更大的威力。

总之,根据上面的这个数字,如果你与itaທ竞争,而且你使用c语言开软件,那么ita的开度将比你快20่倍。如果你需要一年时间实现某个功能,它只需要不到เ三星期。反过来说,如果ita开某个新功能用了三个ฐ月,那么你需要五年才能做出来。

你知道吗?上面的对比还只是考虑到最好的情况。当我们只比较代码数量的时候,言下之意就是假设使用功能较弱的语言也能开出同样的软件。但是事实上,程序员使用某种语言能ม做到เ的事情是有极限的。如果你想用一种低层次的语言解决一个很难的问题,那么你将会面临各种情况极其复杂乃至想不清楚的窘境。

所以,当我说假定你与ita竞争,你用五年时间做出的东西,itaທ在lisp语言的帮助下只用三个月就完成了,我指的五年还是一切顺利、没有犯错误、也没有遇到เ太大麻烦的五年。事实上,按照大多数公司的实际情况,计划中五年完成的项目很可能永远都不会完成。

我承认,上面的例子太极端。ita似乎ๆ有一批非常聪明的黑客,而c语言又是一种很低层次的语言。但是,在一个高度竞争的市场中,即使开度只相差两三倍,也๣足以使得你永远处在落后的位置。

一个诀窍

由á于选择了不当的编程语言而导致项目失败的可能ม性,是你的经理不愿意考虑的问题。事实上大部ຖ分的经理都这样。因为你知道,总的来说,你的经理其实不关心公司是否真的能ม获得成功,他真正关心的是不承担决策失败的责任。所以对他个人来说,最安全的做法就是跟随大多数人的选择。

在大型组织内部,有一个专门的术语描述这种跟随大多数人的选择的做法,叫做“业界ศ最佳实践”。这个词出现的原因其实就是为了让你的经理可以推卸责任。既然我选择的是“业界最佳实践”,如果不成功,项目失败了,那么你也无຀法指责我,因为做出选择的人不是我,而是整个“业界ศ”。

我认为这个词原来是指某种会计方法,大致意思就是不要采用很奇怪的处理方法。在会计方法中ณ,这可能是一个ฐ很好的主意。“尖端”和“核算”这两个ฐ词听上去就不适合放在一起。但是如果你把这个标准引入技术决策,你就开始要出错了。

技术本来就应该是尖端的。正如伊拉恩·加内特所说,编程语言的所谓“业界ศ最佳实践”,实际上不会让你变成最佳,只会让你变得很平常。如果你选择的编程语言使得你开软件的度只有选择更激进技术的对手的几分之一,那ว么“最佳实践”真的起错了名字。

所以,我们就有了两点结论,我认为它们非常有价值。事实上,这是我用自己的经历换来的。第一,不同语言的编程能力不一样。第二,大多数经理故意忽视第一点。你把这两点事实结合起来,其实就得到了赚钱的诀窍。itaທ软件公司是运用这个诀窍的典型例子。如果你想在软件业获得成功,就使用你知道的最强大的语言,用它解决你知道的最难的问题,并且等待竞争对手的经理做出自甘平庸的选择。

附录:编程能力

为了解释我所说的语言编程能ม力不一样,请考虑下面的问题。我们需要写一个函数,它能够生成累加器,即这个函数接受一个参数n,然后返回另一个ฐ函数,后者接受参数i,然后返回n增加in9t了i后的值。这里说的是增加,而不是n和i的相加plus。累加器就是应该完成n的累็加。

摸nlisp

的写法如下:

defunfoon

lambຘdaiin9i

‘下面是一些lisp方แ言生成累加器函数的写法:

scນheme:

definefoon

laທmbdai色t!n+ใnin

goo:dffoonopin9_

ar9_’

ruby的写法几乎完全相同:

deffoon

lambda{|i|n+=i}end

perl5๓的写法则ท是:

subfoo{

my$n=@_ຕ;

subຘ{$n+=shift}

}

这比lisp和ruby的版本有更多的语法元素,因为在perl语言中必须手工ื提取参数。

smalltalk的写法比lisp和ruby的稍微长一点:

foo:n

|s|

s:=n

:i|s:=s+ใi

因为ฦ在smalltalk中,词法变量lexicນalvariable

是有效的,但是你无法给一个ฐ参数赋值,因此不得不设置了一个新变量,接受累加后的值。

‘词法变量,指的是变量的作用域由代码结构决定,不取决于运行时的调用顺序。也就是说,作用域在代码文本的词法分析阶段就决定了,而不在代码执行时决定。注意将这个概ฐ念与“局部变量”的概ฐ念相区分。——译者注’

javascript的写法也๣比lisp和ruby稍微长一点,因为jaທvascript依然区分语句和表达式,所以需要明确指定return语句来返回一个ฐ值:

fun9{

returnfun9i{

returnn+=i}}

实事求是地说,perl也保留了语句和表达式的区别,但是使用了常规的perl方แ式处理,因此可以省略return。