北邮软件工程课件第7章面向对象分析.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《北邮软件工程课件第7章面向对象分析.ppt》由会员分享,可在线阅读,更多相关《北邮软件工程课件第7章面向对象分析.ppt(79页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第第7章章 面向对象分析面向对象分析退出退出 面面向向对对象象分分析析(通通常常缩缩写写为为OOA)OOA)的的关关键键,是是识识别别出出问问题题域域内内的的对对象象,并并分分析析它它们们相相互互间间的的关关系系,最最终终建建立立起起问问题题域域的的简简洁洁、精精确确、可可理理解解的的正正确确模模型型。在在用用面面向向对对象象观观点点建建立立起起的的三三种种模模型型中中,对对象象模模型型是是最最基基本、最重要、最核心的。本、最重要、最核心的。7.1 分析过程分析过程7.2 需求陈述需求陈述7.3 建立对象模型建立对象模型7.4 建立动态模型建立动态模型7.5 建立功能模型建立功能模型7.6 定
2、义服务定义服务7.7 面向对象分析实例面向对象分析实例7.8 小结小结7.1 分析过程分析过程 7.1.1 7.1.1 概述概述 面向对象分析,就是抽取和整理用户需求并建立面向对象分析,就是抽取和整理用户需求并建立问题域精确模型的过程。问题域精确模型的过程。7.1.2 7.1.2 三个子模型与五个层次三个子模型与五个层次 正如本书正如本书6.46.4节所述,面向对象建模得到的模型包节所述,面向对象建模得到的模型包含系统的三个要素,即静态结构含系统的三个要素,即静态结构(对象模型对象模型),交互次,交互次序序(动态模型动态模型)和数据变换和数据变换(功能模型功能模型)。解决的问题不。解决的问题不
3、同,这三个子模型的重要程度也不同:几乎解决任何同,这三个子模型的重要程度也不同:几乎解决任何一个问题,都需要从客观世界实体及实体间相互关系一个问题,都需要从客观世界实体及实体间相互关系抽象出极有价值的对象模型;当问题涉及交互作用和抽象出极有价值的对象模型;当问题涉及交互作用和时序时时序时(例如,用户界面及过程控制等例如,用户界面及过程控制等),动态模型是,动态模型是重要的;解决运算量很大的问题重要的;解决运算量很大的问题(例如,高级语言编译、例如,高级语言编译、科学与工程计算等科学与工程计算等),则涉及重要的功能模型。动态模,则涉及重要的功能模型。动态模型和功能模型中都包含了对象模型中的操作型
4、和功能模型中都包含了对象模型中的操作(即服务或即服务或方法方法)。复杂问题复杂问题(大型系统大型系统)的对象模型由下述五个层次的对象模型由下述五个层次组成:主题层组成:主题层(也称为范畴层也称为范畴层)、类、类&对象层、结构对象层、结构层、属性层和服务层,如图层、属性层和服务层,如图7.17.1所示。所示。图7.1 复杂问题的对象模型 综上所述,我们在概念上可以认为,面向对象分综上所述,我们在概念上可以认为,面向对象分析大体上按照下列顺序进行:寻找类析大体上按照下列顺序进行:寻找类&对象,识别对象,识别结构,识别主题,定义属性,建立动态模型,建立功结构,识别主题,定义属性,建立动态模型,建立功
5、能模型,定义服务。但是,正如前面已经多次强调指能模型,定义服务。但是,正如前面已经多次强调指出过的,分析不可能严格地按照预定顺序进行,大型、出过的,分析不可能严格地按照预定顺序进行,大型、复杂系统的模型需要反复构造多遍才能建成。通常,复杂系统的模型需要反复构造多遍才能建成。通常,先构造出模型的子集,然后再逐渐扩充,直到完全、先构造出模型的子集,然后再逐渐扩充,直到完全、充分地理解了整个问题,才能最终把模型建立起来。充分地理解了整个问题,才能最终把模型建立起来。分析也不是一个机械的过程。大多数需求陈述都分析也不是一个机械的过程。大多数需求陈述都缺乏必要的信息,所缺少的信息主要从用户和领域专缺乏必
6、要的信息,所缺少的信息主要从用户和领域专家那里获取,同时也需要从分析员对问题域的背景知家那里获取,同时也需要从分析员对问题域的背景知识中提取。在分析过程中,系统分析员必须与领域专识中提取。在分析过程中,系统分析员必须与领域专家及用户反复交流,以便澄清二义性,改正错误的概家及用户反复交流,以便澄清二义性,改正错误的概念,补足缺少的信息。面向对象建立的系统模型,尽念,补足缺少的信息。面向对象建立的系统模型,尽管在最终完成之前还是不准确、不完整的,但对做到管在最终完成之前还是不准确、不完整的,但对做到准确、无歧义的交流仍然是大有益处的。准确、无歧义的交流仍然是大有益处的。7.2 需求陈述需求陈述 7
7、.2.1 7.2.1 书写要点书写要点 通常,需求陈述的内容包括:问题范围,功能需通常,需求陈述的内容包括:问题范围,功能需求,性能需求,应用环境及假设条件等。总之,需求求,性能需求,应用环境及假设条件等。总之,需求陈述应该阐明陈述应该阐明“做什么做什么”而不是而不是“怎样做怎样做”。它应该。它应该描述用户的需求而不是提出解决问题的方法。应该指描述用户的需求而不是提出解决问题的方法。应该指出哪些是系统必要的性质,哪些是任选的性质。应该出哪些是系统必要的性质,哪些是任选的性质。应该避免对设计策略施加过多的约束,也不要描述系统的避免对设计策略施加过多的约束,也不要描述系统的内部结构,因为这样做将限
8、制实现的灵活性。对系统内部结构,因为这样做将限制实现的灵活性。对系统性能及系统与外界环境交互协议的描述,是合适的需性能及系统与外界环境交互协议的描述,是合适的需求。此外,对采用的软件工程标准、模块构造准则、求。此外,对采用的软件工程标准、模块构造准则、将来可能做的扩充以及可维护性要求等方面的描述,将来可能做的扩充以及可维护性要求等方面的描述,也都是适当的需求。也都是适当的需求。7.2.2 7.2.2 例子例子 图图7.2 7.2 所示的自动取款机所示的自动取款机(ATM)(ATM)系统,是本书讲系统,是本书讲述面向对象分析和面向对象设计时使用的一个实例。述面向对象分析和面向对象设计时使用的一个
9、实例。图7.2 ATM系统 下面陈述对下面陈述对ATMATM系统的需求。系统的需求。某银行拟开发一个自动取款机系统,它是一个由某银行拟开发一个自动取款机系统,它是一个由自动取款机、中央计算机、分行计算机及柜员终端组自动取款机、中央计算机、分行计算机及柜员终端组成的网络系统。成的网络系统。ATMATM和中央计算机由总行投资购买。总和中央计算机由总行投资购买。总行拥有多台行拥有多台ATMATM,分别设在全市各主要街道上。分行负,分别设在全市各主要街道上。分行负责提供分行计算机和柜员终端。柜员终端设在分行营责提供分行计算机和柜员终端。柜员终端设在分行营业厅及分行下属的各个储蓄所内。该系统的软件开发业
10、厅及分行下属的各个储蓄所内。该系统的软件开发成本由各个分行分摊。成本由各个分行分摊。银行柜员使用柜员终端处理储户提交的储蓄事务。银行柜员使用柜员终端处理储户提交的储蓄事务。储户可以用现金或支票向自己拥有的某个账户内存款储户可以用现金或支票向自己拥有的某个账户内存款或开新账户。储户也可以从自己的账户中取款。通常,或开新账户。储户也可以从自己的账户中取款。通常,一个储户可能拥有多个账户。柜员负责把储户提交的一个储户可能拥有多个账户。柜员负责把储户提交的存款或取款事务输进柜员终端,接收储户交来的现金存款或取款事务输进柜员终端,接收储户交来的现金或支票,或付给储户现金。柜员终端与相应的分行计或支票,或
11、付给储户现金。柜员终端与相应的分行计算机通信,分行计算机具体处理针对某个账户的事务算机通信,分行计算机具体处理针对某个账户的事务并且维护账户。并且维护账户。拥有银行账户的储户有权申请领取现金兑换卡。拥有银行账户的储户有权申请领取现金兑换卡。使用现金兑换卡可以通过使用现金兑换卡可以通过ATMATM访问自己的账户。目前仅访问自己的账户。目前仅限于用现金兑换卡在限于用现金兑换卡在ATMATM上提取现金上提取现金(即取款即取款),或查询,或查询有关自己账户的信息有关自己账户的信息(例如,某个指定账户上的余额例如,某个指定账户上的余额)。将来可能还要求使用将来可能还要求使用ATMATM办理转账、存款等事
12、务。办理转账、存款等事务。所谓现金兑换卡就是一张特制的磁卡,上面有分所谓现金兑换卡就是一张特制的磁卡,上面有分行代码和卡号。分行代码唯一标识总行下属的一个分行代码和卡号。分行代码唯一标识总行下属的一个分行,卡号确定了这张卡可以访问哪些账户。通常,一行,卡号确定了这张卡可以访问哪些账户。通常,一张卡可以访问储户的若干个账户,但是不一定能访问张卡可以访问储户的若干个账户,但是不一定能访问这个储户的全部账户。每张现金兑换卡仅属于一个储这个储户的全部账户。每张现金兑换卡仅属于一个储户所有,但是,同一张卡可能有多个副本,因此,必户所有,但是,同一张卡可能有多个副本,因此,必须考虑同时在若干台须考虑同时在
13、若干台ATMATM上使用同样的现金兑换卡的可上使用同样的现金兑换卡的可能性。也就是说,系统应该能够处理并发的访问。能性。也就是说,系统应该能够处理并发的访问。当用户把现金兑换卡插入当用户把现金兑换卡插入ATMATM之后,之后,ATMATM就与用户就与用户交互,以获取有关这次事务的信息,并与中央计算机交互,以获取有关这次事务的信息,并与中央计算机交换关于事务的信息。首先,交换关于事务的信息。首先,ATMATM要求用户输入密码,要求用户输入密码,接下来接下来ATMATM把从这张卡上读到的信息以及用户输入的密把从这张卡上读到的信息以及用户输入的密码传给中央计算机,请求中央计算机核对这些信息并码传给中
14、央计算机,请求中央计算机核对这些信息并处理这次事务。中央计算机根据卡上的分行代码确定处理这次事务。中央计算机根据卡上的分行代码确定这次事务与分行的对应关系,并且委托相应的分行计这次事务与分行的对应关系,并且委托相应的分行计算机验证用户密码。如果用户输入的密码是正确的,算机验证用户密码。如果用户输入的密码是正确的,ATMATM就要求用户选择事务类型就要求用户选择事务类型(取款、查询等取款、查询等)。当用户。当用户选择取款时,选择取款时,ATMATM请求用户输入取款额。最后,请求用户输入取款额。最后,ATMATM从从现金出口吐出现金,并且打印出账单交给用户。现金出口吐出现金,并且打印出账单交给用户
15、。7.3 建立对象模型建立对象模型 7.3.1 7.3.1 确定类确定类&对象对象 类类&对象是在问题域中客观存在的,系统分析对象是在问题域中客观存在的,系统分析员的主要任务,就是通过分析找出这些类员的主要任务,就是通过分析找出这些类&对象。对象。首先,找出所有候选的类首先,找出所有候选的类&对象;然后,从候选的对象;然后,从候选的类类&对象中筛选掉不正确的或不必要的。对象中筛选掉不正确的或不必要的。1.找出候选的类找出候选的类&对象对象 另一种更简单的分析方法,是所谓的非正式分析。另一种更简单的分析方法,是所谓的非正式分析。这种分析方法以用自然语言书写的需求陈述为依据,这种分析方法以用自然语
16、言书写的需求陈述为依据,把陈述中的名词作为类把陈述中的名词作为类&对象的候选者,用形容词对象的候选者,用形容词作为确定属性的线索,把作为确定属性的线索,把动词作为服务动词作为服务(操作操作)的候选的候选者。者。下面以下面以ATMATM系统为例,说明非正式分析过程。认真系统为例,说明非正式分析过程。认真阅读阅读7.2.27.2.2节给出的需求陈述,从陈述中找出下列名词,节给出的需求陈述,从陈述中找出下列名词,可以把它们作为类可以把它们作为类&对象的初步的候选者。对象的初步的候选者。银行、自动取款机银行、自动取款机(ATM)(ATM)、系统、中央计算机、分、系统、中央计算机、分行计算机、柜员终端、
17、网络、总行、分行、软件、成行计算机、柜员终端、网络、总行、分行、软件、成本、市、街道、营业厅、储蓄所、柜员、储户、现金、本、市、街道、营业厅、储蓄所、柜员、储户、现金、支票、账户、事务、现金兑换卡、余额、磁卡、分行支票、账户、事务、现金兑换卡、余额、磁卡、分行代码、卡号、用户、副本、信息、密码、类型、取款代码、卡号、用户、副本、信息、密码、类型、取款额、账单以及访问。额、账单以及访问。通常,在需求陈述中不会一个不漏地写出问题域通常,在需求陈述中不会一个不漏地写出问题域中所有有关的类中所有有关的类&对象,因此,分析员应该根据领对象,因此,分析员应该根据领域知识或常识进一步把隐含的类域知识或常识进
18、一步把隐含的类&对象提取出来。对象提取出来。例如,在例如,在ATMATM系统的需求陈述中虽然没写系统的需求陈述中虽然没写“通信链路通信链路”和和“事务日志事务日志”,但是,根据领域知识和常识可以知,但是,根据领域知识和常识可以知道,在道,在ATMATM系统中应该包含这两个实体。系统中应该包含这两个实体。2.2.筛选出正确的类筛选出正确的类&对象对象 显然,仅通过一个简单、机械的过程不可能正确显然,仅通过一个简单、机械的过程不可能正确地完成分析工作。非正式分析仅仅帮助我们找到一些地完成分析工作。非正式分析仅仅帮助我们找到一些候选的类候选的类&对象,接下来应该严格考察每个候选对对象,接下来应该严格
19、考察每个候选对象,从中去掉不正确的或不必要的,仅保留确实应该象,从中去掉不正确的或不必要的,仅保留确实应该记录其信息或需要其提供服务的那些对象。记录其信息或需要其提供服务的那些对象。筛选时主要依据下列标准,删除不正确或不必要筛选时主要依据下列标准,删除不正确或不必要的类的类&对象。对象。(1)(1)冗余冗余 (2)(2)无关无关 (3)(3)笼统笼统 (4)(4)属性属性 (5)(5)操作操作 (6)(6)实现实现 综上所述,在综上所述,在ATMATM系统的例子中,经过初步筛选,系统的例子中,经过初步筛选,剩下下列类剩下下列类&对象:对象:ATMATM、中央计算机、分行计算、中央计算机、分行计
20、算机、柜员终端、总行、分行、柜员、储户、账户、事机、柜员终端、总行、分行、柜员、储户、账户、事务和现金兑换卡。务和现金兑换卡。7.3.2 7.3.2 确定关联确定关联 如前所述,两个或多个对象之间的相互依赖、相如前所述,两个或多个对象之间的相互依赖、相互作用的关系就是关联。分析确定关联,能促使分析互作用的关系就是关联。分析确定关联,能促使分析员考虑问题域的边缘情况,有助于发现那些尚未被发员考虑问题域的边缘情况,有助于发现那些尚未被发现的类现的类&对象。对象。在分析确定关联的过程中,不必花过多的精力去在分析确定关联的过程中,不必花过多的精力去区分关联和聚集。事实上,聚集不过是一种特殊的关区分关联
21、和聚集。事实上,聚集不过是一种特殊的关联,是关联的一个特例。联,是关联的一个特例。1.1.初步确定关联初步确定关联 在需求陈述中使用的描述性动词或动词词组,通在需求陈述中使用的描述性动词或动词词组,通常表示关联关系。因此,在初步确定关联时,大多数常表示关联关系。因此,在初步确定关联时,大多数关联可以通过直接提取需求陈述中的动词词组而得出。关联可以通过直接提取需求陈述中的动词词组而得出。通过分析需求陈述,还能发现一些在陈述中隐含的关通过分析需求陈述,还能发现一些在陈述中隐含的关联。最后,分析员还应该与用户及领域专家讨论问题联。最后,分析员还应该与用户及领域专家讨论问题域实体间的相互依赖、相互作用
22、关系,根据领域知识域实体间的相互依赖、相互作用关系,根据领域知识再进一步补充一些关联。再进一步补充一些关联。2.2.筛选筛选 经初步分析得出的关联只能作为候选的关联,还经初步分析得出的关联只能作为候选的关联,还需经过进一步筛选,以去掉不正确的或不必要的关联。需经过进一步筛选,以去掉不正确的或不必要的关联。筛选时主要根据下述标准删除候选的关联。筛选时主要根据下述标准删除候选的关联。(1)(1)已删去的类之间的关联已删去的类之间的关联 (2)(2)与问题无关的或应在实现阶段考虑的关联与问题无关的或应在实现阶段考虑的关联 (3)(3)瞬时事件瞬时事件 (4)(4)三元关联三元关联 (5)(5)派生关
23、联派生关联 3.3.进一步完善进一步完善 应该进一步完善经筛选后余下的关联,通常从下应该进一步完善经筛选后余下的关联,通常从下述几个方面进行改进。述几个方面进行改进。(1)(1)正名正名 (2)(2)分解分解 (3)(3)补充补充 (4)(4)标明阶数标明阶数ATMATM系统原始对象图。系统原始对象图。图7.3 ATM系统原始对象图 7.3.3 7.3.3 划分主题划分主题 在开发大型、复杂系统的过程中,为了降低复杂在开发大型、复杂系统的过程中,为了降低复杂程度,人们习惯于把系统再进一步划分成几个不同的程度,人们习惯于把系统再进一步划分成几个不同的主题,也就是在概念上把系统包含的内容分解成若干
24、主题,也就是在概念上把系统包含的内容分解成若干个范畴。个范畴。图7.4 把ATM系统划分成三个主题 7.3.4 7.3.4确定属性确定属性 一般说来,确定属性的过程包括分析和选择两个一般说来,确定属性的过程包括分析和选择两个步骤。步骤。1.1.分析分析 属性的确定既与问题域有关,也和目标系统的任属性的确定既与问题域有关,也和目标系统的任务有关。应该仅考虑与具体应用直接相关的属性,不务有关。应该仅考虑与具体应用直接相关的属性,不要考虑那些超出所要解决的问题范围的属性。在分析要考虑那些超出所要解决的问题范围的属性。在分析过程中应该首先找出最重要的属性,以后再逐渐把其过程中应该首先找出最重要的属性,
25、以后再逐渐把其余属性增添进去。在分析阶段不要考虑那些纯粹用于余属性增添进去。在分析阶段不要考虑那些纯粹用于实现的属性。实现的属性。2.2.选择选择 认真考察经初步分析而确定下来的那些属性,从认真考察经初步分析而确定下来的那些属性,从中删掉不正确的或不必要的属性。通常有以下几种常中删掉不正确的或不必要的属性。通常有以下几种常见情况。见情况。(1)(1)误把对象当作属性误把对象当作属性 (2)(2)把链属性误作为属性把链属性误作为属性 (3)(3)把限定误当成属性把限定误当成属性 (4)(4)误把内部状态当成了属性误把内部状态当成了属性 (5)(5)过于细化过于细化 (6)(6)存在不一致的属性存
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程 课件 面向 对象 分析
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内