有一位名叫克拉克的大富豪,名列世界富豪榜Top10,钱多得花不了,很想去非洲玩乐挥霍一番,于是他拨通了一份广告上的电话:嘿,小子,听好了,我要去非洲狩猎,要订购你们公司最顶级的狩猎设备,越快越好,10天后我在非洲接货…。 10天以后,狩猎设备如期交货,是一辆最新款的顶级法拉利跑车。特别之处在于车的前盖上装备了一把勃朗宁造的顶级猎枪,在车里配备了一套世界最顶级的猎枪自动装弹、瞄准和射击的控制系统,它使得驾驶员在车里就可以轻松操控猎枪进行射击。克拉克立刻被这种别致、高档的设计所征服了,带着他的私人保镖,迫不及待地跳上跑车绝尘而去。伴随着高亢的重金属摇滚,以300麦的高速在非洲大草原上狂奔,野生动物在身边纷纷闪过。克拉克通过自动火控系统,快速地瞄准他中意的猎物,轻轻一按发射按钮,猎物应声倒地。克拉克由衷的赞叹:哇塞,这设备实在是太酷了,连车身的速度和角度都被自动融合到弹道的计算中了,弹无虚发啊!爽! 酣畅淋漓地狂奔了一小时后,克拉克驾车来到了一座山丘的附近,与此同时,他很幸运地发现了号称奔跑速度最快的非洲猎豹。于是,他立刻驱车靠近。但是,法拉利巨大的轰鸣声立刻引起了猎豹的警觉,拔腿就跑,一转眼就不见了踪影。克拉克紧追不舍,来到了一篇丛林边。为了继续追赶猎豹,克拉克只好命令保镖随同他下车,来到车前方,想要取下猎枪进行徒步狩猎。然而,此时他才发现,这猎枪是焊接在车盖上的,根本无法取下。“Shit!”,克拉克非常扫兴,忍不住骂了一声。他回头看了看四个身强力壮的保镖,计上心来:兄弟们,给我抬着车前进。四个保镖虽然非常不愿意,但是毕竟是收人钱财了,只好硬着头皮抬起法拉利进入了丛林… 三天以后,克拉克返回了自己的豪华别墅。第一件事就是电话投诉:“你们的狩猎设备太烂了,猎枪居然焊接在车盖上,完全毁了我的旅程,我要投诉…”。狩猎设备公司的销售人员非常的委屈:我们的设备多好啊,又能快速移动,又能精准射击,法拉利和勃朗宁的结合难道不是完美的顶级组合吗?”。 这个虚构的小故事到此结束,你有没有觉得它和软件设计有任何关系?再直接一点提问:你在设计软件的时候,是否曾经干过把猎枪焊接在法拉利身上的事情?可以坦诚地告诉你,我有,只不过那是一个变形的袖珍版,我曾经把照相机焊接在自行车上。 把没有必然关联的两个部分有意识或无意识地揉在一起,只是因为你觉得在某个场合你会同时需要他们。这种蹩脚的耦合,是蹩脚软件设计的一大主因,甚至在我看来是最大的主因。当我回顾自己做过的软件设计时,90%的不良设计都是由这种蹩脚的耦合造成的。去除耦合,说起来很简单,做起来却真的很难,很多人都是在无意识之中就把猎枪焊接在法拉利身上了,就因为觉得会同时需要它们,而没有经过足够仔细和慎重的推敲。 当猎枪焊接在法拉利身上以后,如果你需要一支可以徒步狩猎的猎枪,你要么再复制一支一模一样的,要么就扛着法拉利去打猎吧。这样的事情,在蹩脚的软件设计中,每天都在发生。