焦油坑

史前史中,没有别的常见比巨兽们再焦油坑中垂死挣扎的场面更令人震撼。上帝见证着恐龙、猛犸象、剑齿虎再焦油中挣扎。它们挣扎的越猛烈,焦油纠缠得就越紧,没有那种猛兽足够强壮或具有足够的技巧,能够挣脱束缚,它们最后都沉到了坑底。

过去几十年的大型系统开发就犹如这样一个焦油坑,很多大型和强壮的动物再其中剧烈地挣扎。他们中大多数开发出了可运行的系统--不过只有极少数的项目满足了目标、进度和预算的要求。各种团队,大型的或小型的,庞杂的或精干的,一个接一个地淹没在了焦油坑中。表面上看起来好像没有任何一个单独的问题会导致困难,每个问题都能获得解决,但是当它们相互纠缠和积累再一起的时候,团队的行动就会变得越来越慢。对于问题的满分程度,每个人似乎都会感到惊讶,并且河南看清问题的本质。不过,如果哦我们像解决问题,就必须试图先去了解问题。

因此,首先让我们来认识一下系统开发这个职业,已经充满再这个职业中的乐趣和苦恼吧!

编程是系统产品

报纸上经常会出现这样的新闻,讲述两个程序员如何再经过改造的简陋车库中,编出超过大型团队工作量的重要程序。接着,每个编程人员准备相信这样的神话,因为他知道自己能已超过产业化团队的1000代码行/年的生产率来开发任何程序。

为什么不是所有的产业化队伍都会被这种专注的二人组合所替代?我们必须看一下产出的是什么。

左上部分是程序。它本身是完整的,可以由作者再所开发的系统平台上运行。它通常是车库中产出的产品,以及作为单个程序员生产率的评估标准。

有两种途径可以使程序转变成更有用但是成本更高的产物,这两种途径表现为图中的边界。

水平边界以下,程序转变成编程产品。这是可以被任何人运行、测试、修复和扩展的程序。它可以在多种操作系统平台上运行,供多套数据使用。要称为通用的编程产品,程序必须按照普遍认可的风格来编写,特别是输入的范围和形式必须广泛地适用于所有可以合理使用的基本算法。接着对程序进行彻底测试,确保它的稳定性和可靠性,使其值得信赖。这就意味着必须准备、运行和记录详尽的测试用例库,用来检查输入的边界和范围。此外,要将程序提升为程序产品,还需要有完备的文档,每个人都可以加以是哟个、修复和扩展。经验数据表明,相同功能的编程产品的成本,至少是已调试的程序的成本的3倍。

回到图中,垂直边界的右边,程序转变成编程系统中的一个构建单元。它是功能上能相互协作、具有规划的格式、可以进行交互的程序集合,并可以用来组织和搭建整个系统。要称为编程系统构建,程序必须按照一定的要求编制,使输入和输出在预防和语义上与精确定义的接口一致。同事程序还要符合预先定义的资源限制--内存空间、输入输出设备、计算机时间。最后,程序必须同其他系统狗啊就单元一道,以任何能想象到的组合进行测试。由于测试用例会随着组合不断增加,所以测试的范围必须广泛。因为一些意想不到的交互会产生许多不易察觉的bug,测试工作将会非常耗时,因此相同共功能的编程系统构件的成本至少是独立程序的3倍。如果系统有大量的组成单元,成本还会更高。

右下部分代表编程系统产品。与以上的所有的简单的程序都不同的是,它的成本高达9倍。然而,只有它才是真正有用的产品,是大多数系统开发的目标。

职业的乐趣

职业的苦恼

results matching ""

    No results matching ""