Jolt大奖精选丛书
面向对象分析与设计(第3版)权威精选植根于开发实践的最佳读物
(美) 布奇(Booch,G.) 等著
王海鹏,潘加宇译
ISBN978-7-121-17389-9
2012年7月出版
定价:99.00元
16开
608页
宣传语:一项技术产品只有在获得了Jolt奖之后才能真正成为行业的主流,一本技术图书只有在获得了Jolt奖之后才能真正奠定经典的地位。
内 容 简 介
本书是UML创始人Grady Booch的代表作之一。
全书分为理论和应用两部分。理论部分深刻剖析了面向对象分析与设计(OOAD)的概念和方法。应用部分连续列出了5个不同类型、不同领域的应用,描述如何从初始阶段到交付阶段,将OOAD理论和方法应用到项目中。应用部分所涉及的领域包括系统架构、数据获取、密码分析、控制系统和Web开发,还给出了一些关于重要问题的有效建议,包括分类、实现策略和高性价比的项目管理。
书中介绍的概念都基于牢固的理论基础。同时,作者十分注重实效,基于其丰富的经验,面向软件工程实践者的实际需要,提出了改进的对象开发方法,用于解决系统和软件开发者面临的复杂问题;运用大量例子说明了基本概念,解释了方法,并展示了在不同领域的成功应用。
书中的表示法采用最新的UML 2.0,因此本书是学习UML2.0不可多得的参考书。
本书非常适合实际系统和软件的开发者、系统分析师或架构师、项目经理阅读,也可以作为高等院校软件工程和高级编程课程的教材使用。
出版说明
经久不息的回荡
今时的读书人,不复有无书可读之苦,却时有品种繁多而无从择优之惑,甚而专业度颇高的技术书领域,亦日趋遭逢乱花迷眼的境地。此时,若得觅权威书评,抑或有公信力的排行榜,可按图索骥,大大增加选中好书的命中率。然而,如此良助,不可多得,纵观中外也唯见一枝独秀——素有“软件业奥斯卡”之美誉的Jolt奖!
震撼世界者为谁
在计算设备已经成为企业生产和日常生活之必备工具的今天,专业和大众用户对于软件的功能、性能和用户体验的要求都在不断提高。在这样的背景下,如何能够发挥出软件开发的最高效率和最大效能,已经是摆在每一个从业者面前的重大课题,而这也正是Jolt大奖横空出世的初衷及坚持数年的宗旨。
Jolt大奖历时20余年,在图书及软件业知名度极高,广受推崇。奖如其名,为引领计算机科学与工程发展主流,Jolt坚持将每年的奖项只颁给那些给整个IT业界带来震撼结果的图书、工具、产品及理念等,因一流的眼光及超高的专业度而得以闻名遐迩,声名远播。
除图书外,Jolt针对软件产品设有诸多奖项分类,如配置管理、协作工具、数据库引擎/数据库工具、设计工具/建模、开发环境、企业工具、库/框架、移动开发工具等。但图书历来是Jolt大奖中最受瞩目且传播最广的一个奖项分支。Jolt曾设有通用类图书、技术类图书等分类,每个分类又设有“卓越奖”(Jolt Award,一般为一个)和“生产力奖”(ProductivityAward,一般为2或3个)。获奖技术图书一经公布,即打上经典烙印,可谓一举“震撼全世界”(赞助商Jolt可乐的广告词)。
作为计算机技术图书的后进,我们总在追问——是谁在震撼世界,是谁在照亮明天?Jolt大奖恰似摆在眼前的橱窗,让我们可以近距离观看潮流在舞蹈,倾听震撼在轰鸣!
朝花夕拾为哪般
Jolt像是一年一度的承诺,在茫茫书海中为我们淘砺出一批批经得起岁月冲刷的杰作,头顶桂冠的佳作也因而得以一批批引进中国,为国人开阔了眼界,滋补了技术养分。然而,或因技术差距造就的生不逢时、水土不服,或因翻译、制作的不如人意,抑或是疏于宣传等诸多原因,这些经典著作在国内出版后,尽管不乏如获至宝的拥趸,却仍不为诸多人所知,从而与大量本应从中获益的读者擦肩而过。既然这生生错失的遗憾本不该发生,则更不应延续。为此,我们邀国外出版同行、国内技术专家一道,踏上朝花夕拾之路,竭力为广大读者筛选出历久弥新、震撼依旧的Jolt图书精品。
Jolt获奖图书皆由业界专家一致评出,并得到软件从业人员的高度认可,虽然这些书今天读来,不再能看到上世纪史诗时代那般日新月异的理论突破,以及依赖于高深繁复的科学研究所取得的系统化成果,更多是在日复一日的开发实践中总结和提炼出来的工程思想和方法论。重新选材之所以有所弃取,从Jolt多年来的评奖规律中可窥端倪——
一万小时真理见
凡是在工程思想领域取得革命性、颠覆性突破的图书,就被归于“震撼”获奖分类。比如,从基于过程的程序设计模型过渡到面向对象的全新模型,就是软件开发思想上的一次带来巨大震撼的革命;再比如,打破传统的瀑布模型而转向持续集成的软件交付模型,这也是一场业界的重大思想转变。像这样的重大思想突破,可以说是数年甚至数十年一遇的,而荣获Jolt大奖的图书中更为常见的,则是基于最佳实践的“生产效率”获奖者。获得此类殊荣的图书,都是作者们从平凡的、重复的,甚至用一般人的眼光看来不怎么起眼的日常开发实践中,以独具的慧眼、过人的耐心和大胆的创新,闯开一条不平常道路的心血与经验总结。
这些图书所涉及的主题,都是普通的软件开发人员每天要面对的工作——代码阅读、撰写测试用例、修复软件问题……但就是这样貌似平淡无奇的工作,是否能每一天、每一个项目都做好,着实拉开了软件开发人员素质的差距,也决定了软件企业开发出来的产品和服务的质量。我们中国有一句古话,叫做熟能生巧;某位著名企业家也说过一句家喻户晓的名言:“把简单的事千百万次地做好,就是不简单的。”这些朴素而实际的真理,同样也是本套丛书最能彰显的所谓程序员精神。它建立在脚踏实地的实践基础之上,也充满了对于自由和创新的向往。
名作可堪比名曲
就不因岁月流逝而褪色来说,与这些Jolt名作相媲美者,只有那些百年响彻、震撼古今的经典名曲。希望本丛书带给大家的每部著作,也如百听不厌的乐曲,掩卷良久方余音绕梁,真知存心。仔细想来,软件开发与古典音乐岂非有异曲同工之妙?既是人类心智索问精确科学的探究,亦是寻觅美学享受的追求。工程是艺术的根基,而艺术是工程的极致。衷心地希望各位读者能够认真阅读本丛书的本本珍品,并切实地用于自己的日常工作中,在充分享受大师魅力的同时,为中国的软件事业谱写更多、更震撼的乐章。
电子工业出版社博文视点
二零一二年春
特别的Booch,特别的书
以下几点也许是您购买本书的理由。
1.读过Robert C.Martin的Agile Principles的读者,很容易注意到该书前言的第一句话,“Bob,你说过去年就能写完这本书的——ClaudiaFrers在1999年UML World大会上抱怨。”“这本书”指的是Robert C. Martin在20世纪90年代的代表作DesigningObject-Oriented C++ Application using the Booch Method。Agile Principles本来是作为Designing一书的第2版。由此可见,RobertC. Martin深受Booch的影响。
2.Grady Booch是最早提出面向对象分析设计方法的方法学家之一。20多年来,Grady Booch一直担任Rational公司的首席科学家,随着Rational成长,收购别人,被别人收购,CEO换了又换,他也没有离开。GradyBooch是UML三友中唯一的IBM院士。
3.Grady Booch非常“与时俱进”,其Blog(http://www.ibm.com/developerworks/blogs/ page/gradybooch)更新频繁,即使在心脏主动脉瘤动手术期间,他也一直在病床上更新Blog。他还热衷于SecondLife,认为Second Life是一条协作软件开发的新道路。GradyBooch在Second Life上的化身叫做AlemTheas。Dr. Dobb在给他颁发程序设计杰出奖(Excellencein Programming Award)的时候,就是在Second Life上进行的。
4.本书是真正展示Booch思想的书。我们可以在UML三友署名的UML系列书籍封面上看到Grady Booch的名字,但其中大多数工作是由JamesRumbaugh完成的。
5.本书分为理论和应用两部分。理论部分(概念和方法)的叙述朴实无华,标题简洁:“复杂性”、“对象模型”、“类和对象”、“分类”、“表示法”、“过程”……用平实的语言把内容剖析得很透彻。应用部分连续列出了5个不同类型、不同领域的应用,描述如何从初始阶段到交付阶段,把前面所授方法应用到项目中。
基于卫星的导航系统:聚焦于系统架构;
列车交通控制系统:聚焦于系统需求;
人工智能解密系统:聚焦于分析;
气象站数据采集系统:聚焦于分析到初步的设计;
雇员休假跟踪Web应用系统:聚焦于详细设计和实现。
6.书中的表示法采用最新的UML2.0,画图工具是IBM Rational Software Architect和Sparx Systems Enterprise Architect。也就是说,Grady Booch使用了非IBM公司的UML工具来写自己的书。
潘加宇
2012年1月
前 言
人类渴望得到精神上的宁静、美学上的成就、家庭的安全、正义和自由。这一切都不能通过工业化的生产效率来直接满足。但是,生产效率让人们得到充足的物质享受,而不至于与匮乏苦苦斗争。这为精神、美学和家庭事务赢得了时间,也使得社会能够将一些特殊的技能赋予司法机构以及维护权利的机构。
Harlan Mills
DPMA and Human Productivity
作为计算机专业人员,我们努力地去构建能工作而且有用的系统;作为软件工程师,我们面临着在计算资源和人力资源有限的条件下创建复杂系统的任务。面向对象(OO)技术已经发展为管理许多不同种类的系统中内在复杂性的手段。对象模型已被证明是非常有力和统一的概念。
对第2版的改动
在本书第2版出版以后,我们看到了一些重要的技术进步,其中一些突出的进步如下。
与因特网的高带宽、无线连接已经非常普遍;
纳米技术已经出现,并开始提供有价值的产品;
机器人在火星表面漫步;
计算机生成的特效使得在电影中能够完全逼真地再现任何想象中的世界;
出现了个人气垫船;
手机已无处不在,使用非常方便;
获得了人类基因图谱;
面向对象技术已经在工业软件开发中成为主流技术。
在世界各地都能见到面向对象技术被使用。但是,我们仍然遇到许多人,他们还没有采用面向对象的开发方式。对于这两类人,本书的新版本都很有价值。
对于面向对象分析与设计(OOAD)的新手,本书提供了下列信息。
面向对象的概念支持和演进式的观点;
如何在系统开发生命周期中应用OOAD的例子;
对系统和软件开发中使用的标准表示法统一建模语言(UML 2.0)的介绍。
对于有经验的OOAD实践者,本书从不同的角度提供了价值。
即使对于有经验的实践者,UML 2.0也是新的。这是可以看到表示法方面的重要区别。
根据前一版本所收到的反馈,更加关注建模。
通过本书的概念部分的学习,可以了解在面向对象的世界中,“为什么事情总是像它们现在的样子”。许多人可能从没研究过面向对象(OO)概念本身的发展,即使有所了解,在初次学习OO方法时,也许未能理解其重要性。
本书这一版和以前的版本相比有4项主要区别,如下所示。
1.UML 2.0已经正式得到了通过,第5章将介绍UML 2.0。为了加强读者对这种表示法的理解,特别区分了它的基本元素和高级元素。
2.这一版在应用程序的章节中引入了一些新的领域和背景。例如,应用程序的领域范围很广,包括从高级系统架构到基于Web的系统的设计细节等各种不同层次的抽象。
3.在前一版出版时,作为OO编程的概念来说,C++相对还是比较新的。读者告诉我们,这种强调不再是主要的考虑。现在有大量的OO编程和技术书籍及培训,还有许多为OO开发而设计的编程语言。因此,大部分关于编码的讨论被删除了。
4.最后,响应读者的要求,这一版更关注OOAD建模方面。应用程序章节将展示如何利用UML,其中每一章强调了整个开发生命周期中的一个阶段。
本书的目标
本书在面向对象系统构建方面提供了实用指导。它的具体目标如下。
提供对对象模型的基础概念及其发展变化的正确理解;
帮助读者掌握面向对象分析和设计的表示法和过程;
介绍在不同的问题域中面向对象分析和设计的实际应用。
本书介绍的概念都基于牢固的理论基础,但本书首先是一本注重实效的书,面向架构师和软件开发者等软件工程实践者的实际需要。
读者对象
本书既是为计算机专业人员也是为学生编写的。
对于实际系统和软件的开发者,本书将展示如何高效地利用面向对象技术来解决实际问题。
对于系统分析师或架构师,本书将利用面向对象的分析与设计,提供一条从需求到实现的途径。我们帮助分析人员或架构师提高识别能力,以区分不好的面向对象的结构与好的面向对象的结构,并在现实情况反常时权衡可选的设计方案。也许最重要的就是,我们提供了一些让复杂系统变得有条理的新方法。
对于项目经理,本书可以帮助他们更好地理解开发团队的资源分配、软件品质、测量指标以及管理与复杂软件系统相关的风险。
对于学生,本书提供了一些必要的指导,使得学生能够开始掌握复杂系统开发的科学与艺术中的一些重要技巧。
本书不仅适合专业研讨班和个人学习使用,也适合作为高等院校本科生和研究生课程的教材。因为它主要阐述了软件开发的方法,所以非常适合软件工程和高级编程等课程,也可以作为涉及具体面向对象编程语言的课程的补充阅读材料。
本书的组织结构
本书分成3篇:概念、方法和应用,其中穿插了大量的补充材料。
概念
第1篇研究软件的内在复杂性及其表现方式。本书将对象模型作为一种手段来帮助我们管理这种复杂性,详细地研究了对象模型的基本元素——抽象、封装、模块化、层次结构,讨论了“什么是类?”以及“什么是对象?”等基本问题。由于确定有意义的类和对象是面向对象开发中的关键任务,因此我们花了相当多的时间来研究分类的本质。具体来说,我们研究了生物学、语言学和心理学等其他学科中的分类方法,然后将这些经验应用到发现软件系统中类和对象的问题上。
方法
第2篇基于对象模型提出了复杂系统开发的一种方法。针对面向对象的分析与设计,首先提出了一套图形表示法(即UML),然后是一个通用的过程框架。还研究了面向对象开发的实践,具体来说,就是它在软件开发生命周期中的位置以及它对于项目管理意味着什么。
应用程序
第3篇提供了一组(5个)不简单的例子,涉及不同问题域:系统架构、控制系统、密码分析、数据获取和Web开发。之所以选择这些问题域,是因为它们是软件工程师实践过程中遇到的复杂问题的代表。展示某些原则如何应用于简单的问题是很容易的,但是因为我们关注的是为现实世界构建有用的系统,所以我们对如何将对象模型应用于复杂应用程序更加感兴趣。软件系统的开发不同于按菜谱做菜,因此我们强调应用程序的增量式开发,这种开发以一些正确的原则和良好的模型作为指导。
补充材料
本书中穿插了大量的补充资料。多数章节中都有补充材料,这些材料对重要的主题提供了相关的信息。本书包括了一个关于面向对象编程语言的附录,其中总结了一些常见语言的特征,还提供了常用术语的词汇表,以及一个扩展的分类参考书目,列出了关于对象模型的参考资料。
工具说明
读者总是会问创建本书中的图使用了什么工具。我们主要使用两个很好的工具来画图:IBM Rational Software Architect和Sparx Systems Enterprise Architect。为什么不只用一个?市场的实际情况是,没有哪一种工具可以做所有的事情。实践OOAD的时间越长,最后就会发现有些特别的情况是所有工具都不支持的。(在这种情况下,可能需要寻求基本的绘图工具来展示你的想法。)但是,不要让这些很少的情况阻止你使用健壮的OOAD工具,如我们提到的这两种工具。
本书的阅读方法
对于本书可以一页一页地读,也可以不按现有的组织形式阅读。如果想对对象模型中的基本概念或面向对象开发的动机有较深的理解,那么就应该从第1章开始依次读下去。如果只对面向对象开发分析与设计中的表示法和过程感兴趣,就从第5章和第6章开始阅读。第7章对使用这种方法管理项目的管理者来说特别有用。如果对针对特定问题域的面向对象技术的应用程序更感兴趣,则可以在第8~12章中任选一章或者全部阅读。
致 谢
我把本书献给我的妻子Jan,感谢她的爱和支持。
在第1版和第2版的写作过程中,一些人促成了我的面向对象开发思想。对于他们的贡献,我特别要感谢,他们是:Sam Adams、Mike Akroid、Glenn Andert、Sid Bailin、Kent Beck、DaveBernstein、Daniel Bobrow、Dick Bolz、Dave Bulman、Kayvan Carun、Dave Collins、Damian Conway、Steve Cook、Jim Coplien、Brad Cox、WardCunningham、Tom DeMarco、Mike Devlin、Richard Gabriel、WilliamGenemaras、Adele Goldberg、Ian Graham、Tony Hoare、Jon Hopkins、Michael Jackson、Ralph Johnson、James Kempf、Norm Kerth、Jordan Kreindler、Doug Lea、Phil Levy、BarbaraLiskov、Cliff Longman、JamesMacFarlane、Masoud Milani、Harlan Mills、Robert Murray、Steve Neis、Gene Ouye、Dave Parnas、Bill Riddel、Mary BethRosson、Kenny Rubin、Jim Rumbaugh、Kurt Schmucker、Ed Seidewitz、Dan Shiffman、DaveStevenson、Bjarne Stroustrup、Dave Thomas、Mike Vilot、Tony Wasserman、Peter Wegner、Iseult White、John Williams、LloydWilliams、Niklaus Wirth、Mario Wolczko和Ed Yourdon。
本书的相当一部分实践来自我参与并在世界各地开发的复杂软件系统,这些系统的开发公司包括Alcatel、AndersenConsulting、Apple、AT&T、Autotrol、Bell NorthernResearch、Boeing、Borland、Computer Sciences Corporation、Contel、Ericsson、Ferranti、GeneralElectric、GTE、HollandSignaal、Hughes Aircraft Company、IBM、Lockheed、Martin Marietta、Motorola、NTT、Philips、Rockwell International、Shell Oil、Symantec、Taligent和TRW。我曾有机会与数百名专业软件工程师和他们的经理协作,我要谢谢他们的帮助,是他们让本书与真实世界的问题相关。
特别要感谢Rational对我的工作的支持。还要谢谢TonyHall,他的卡通画给本书带来了亮点,否则这本书就只是一本乏味的技术书籍。最后,我要谢谢我的3只猫——Cammy、Annie和Shadow,在我写作的许多个深夜,它们总是陪伴着我。
——Grady Booch
我要感谢我的家人,他们必须忍受我参与编写这本书的漫长日子。感谢我的父母,他们培育了我高尚的职业道德。感谢Mary T.O’ Brien,她为我提供了这个机会,这才使我开始了大量的后续工作。感谢Chris Guzikowski帮助推动这项工作直至完成。我要感谢合著者,感谢你们允许我加入这项工作,也感谢你们在这个项目中的努力工作和贡献。最后,我要衷心感谢Grady多年前编写的本书的第1版,这本书是关于面向对象分析与设计最早的、最基础的书之一。
——Bob Maksimchuk
我想表达对家人的感激,他们给了我爱和支持,这是我所有努力的基础。感谢Grady给我机会,让我能够在他的经典著作的第3版中做出贡献。最后,我要感谢Bob Maksimchuk在我成为一名作者的过程中所给予的指导。
——Mike Engle
我要将本书献给我的母亲Jean Smith,她鼓励我参加这项工作。我也要表达我对家人Russell、Alyssa和Logan的爱和感激,感谢他们的支持和鼓励。感谢BobMaksimchuk和Mike Engle,是他们让我有机会参与这项工作。
——Bobbi J. Young
我要特别感谢我的丈夫Bob和两个孩子——Katherine和Ryan,他们的爱和支持给我了真正的灵感。
——Kelli A. Houston
感谢我们的审稿者,特别是Davyd Norris和Brian Lyons。感谢Addison-Wesley所有参与本书的其他工作人员,特别是ChrisZahn,他不仅参与了这项工作,而且保持了这项长时间工作的连贯性。
作者简介
Grady Booch在软件架构、软件工程和建模领域的创新工作是世界知名的。从1981年Rational公司创建开始,他就一直担任该公司的首席科学家。Grady于2003年3月成为了IBM院士(IBM Fellow)。
Grady是统一建模语言(UML)最早的开发者之一,也是几个Rational产品的最早开发者之一。Grady曾担任世界各地一些复杂的软件密集型项目的架构师和架构指导者。
Grady是6本畅销书的作者,包括UML Users Guide和Object-OrientedAnalysis with Applications。Grady发表了几百篇有关软件工程的技术文章,其中包括在20世纪80年代早期发表的文章,这些文章最先提出了面向对象设计的术语和实践。他曾在世界各地演讲和咨询。
Grady是美国计算机协会(ACM)、美国电气电子工程师学会(IEEE)、美国科学促进会(AAAS)、有社会责任的计算机专家协会(CPSR)的成员。他是IBM院士、ACM院士、世界技术网络院士,也是软件开发论坛梦想家。Grady是敏捷联盟、Hillside集团和软件架构师世界学院的创始委员会成员,也是Northface大学的顾问委员会成员。
Grady于1977年从美国空军学院获得学士学位,于1979年从加州大学圣巴巴拉分校获得电子工程科学硕士学位。
Grady与他的妻子和他的猫生活在科罗拉多。他的兴趣包括阅读、旅行、唱歌和弹奏竖琴。
Robert A. Maksimchuk是Unisys ChiefTechnology Office的一名研究主管。他关注新出现的建模技术,目的是提升Unisys 3D可视企业建模框架的战略方向。Bob为这项任务带来了不同行业的大量系统工程、建模、面向对象分析与设计的专业知识。他是UML for Mere Mortals和UML forDatabase Design的合著者,也写了许多文章。他曾经周游世界各地,在各种技术论坛上作为重要演讲者发言,举办关于UML和面向对象开发的研讨会和培训。Bob是电气电子工程师学会(IEEE)和国际系统工程学会(INCOSE)的成员。
Michael W. Engle是洛克希德马丁公司的首席工程师。他有超过26年的技术和管理经验——从项目启动到运营支持,涵盖了完整的系统开发生命周期。利用系统工程师、软件工程师和系统架构师的背景,Mike运用了面向对象技术,为复杂的系统开发提供创新的开发方式。
Bobbi J. Young, Ph.D.是Unisys ChiefTechnology Office的一名研究主管。她有着多年的IT行业从业经验,与商业公司和国防部合同供应商一同工作。Young博士是一名咨询师,她在项目管理、企业架构、系统工程和面向对象分析与设计方面提供现场指导。在她的职业生涯中,她关注于系统生命周期过程和方法学,同时也关注企业架构。Young博士拥有生物学、计算机科学和人工智能学位,她获得了管理信息系统的博士学位,也曾是美国海军预备役的一名指挥官(已退伍)。
Jim Conallen是IBM Rational的模型驱动开发战略小组的一名软件工程师。在这个小组中,他积极参与,将对象管理集团(OMG)的模型驱动架构(MDA)计划应用于IBM Rational的模型工具中。Jim在基于资产的开发和可复用资产规范(RAS)领域也很活跃。Jim经常在会议上演讲,也经常写文章。他的专业领域是Web应用开发。
他开发了UML的Web应用扩展(WAE)。这是对UML的一种扩展,让开发者能够利用UML在合适的抽象和细节层面上对Web应用的架构进行建模。这项工作是IBM Rational Rose和Rational XDEWeb Modeling功能的基础。
Jim与人合著了两个版本的BuildingWeb Applications with UML,第一个版本采用微软公司的ASP技术,后一个版本采用J2EE技术。
Jim的经验也来自于加入Rational之前的工作,那时他曾是独立的咨询师、Peace Corps的志愿者和大学讲师。他还是3个孩子的父亲。Jim从Widener大学获得了计算机和软件工程的学士学位和硕士学位。
Kelli Houston是IBM Rational的IT咨询专家。她是IBM内部方法的方法架构师,负责编写方法并集成IBM的方法。除了方法架构师的角色,Kelli还在IBM内部领导RationalMethod Composer(RMC)特别兴趣小组(SIG)工作,为客户和IBM内部咨询师提供有效使用RMC方面的咨询和现场指导服务。