面向对象分析 讲稿.ppt
《面向对象分析 讲稿.ppt》由会员分享,可在线阅读,更多相关《面向对象分析 讲稿.ppt(71页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第十章第十章 面向对象分析面向对象分析面对的问题面对的问题当开发一个新的产品或系统时,我们如当开发一个新的产品或系统时,我们如何从遵循何从遵循OOOO软件工程的方式来刻画它?软件工程的方式来刻画它?什么是相关的对象?他们如何相互关联什么是相关的对象?他们如何相互关联?对象如何在系统的范围内工作?对象如何在系统的范围内工作?应如何对问题刻画或建模以使得可有效应如何对问题刻画或建模以使得可有效地进行设计?地进行设计?10.3 10.3 建立对象模型建立对象模型对象模型通常有五个层次。典型的工作步对象模型通常有五个层次。典型的工作步骤是,首先确定骤是,首先确定对象类和关联对象类和关联(因为它们影响(
2、因为它们影响系统整体结构和解决问题的方法),对于大型系统整体结构和解决问题的方法),对于大型复杂问题还要进一步复杂问题还要进一步划分出若干个主题划分出若干个主题;然后;然后给类和关联给类和关联增添属性增添属性,以进一步描述它们;接,以进一步描述它们;接下来利用适当的继承关系进一步下来利用适当的继承关系进一步合并和组织类合并和组织类。而对类中操作的最后确定,则需等到而对类中操作的最后确定,则需等到建立了动建立了动态模型和功能模型态模型和功能模型之后,因为这两个子模型更之后,因为这两个子模型更准确地描述了对类中提供的服务的需求。准确地描述了对类中提供的服务的需求。10103 31 1 确定类对象确
3、定类对象1 1找出候选的类对象找出候选的类对象对象是对问题域中有意义的事物的抽象,它们对象是对问题域中有意义的事物的抽象,它们既可能是物理实体,也可能是抽象概念。既可能是物理实体,也可能是抽象概念。具体地具体地说,大多数客观事物可分为下述五类说,大多数客观事物可分为下述五类(1 1)可感知的物理实体)可感知的物理实体,例如,飞机、汽车、书、房,例如,飞机、汽车、书、房屋等等。屋等等。(2 2)人或组织的角色)人或组织的角色,例如,医生、教师、雇主、雇,例如,医生、教师、雇主、雇员、计算机系、财务处等等。员、计算机系、财务处等等。(3 3)应该记忆的事件)应该记忆的事件,例如,飞行、演出、访问、
4、交,例如,飞行、演出、访问、交通事故等等。通事故等等。(4 4)两个或多个对象的相互作用)两个或多个对象的相互作用,通常具有交易或接,通常具有交易或接触的性质,例如,购买、纳税、结婚等等。触的性质,例如,购买、纳税、结婚等等。(5 5)需要说明的概念)需要说明的概念,例如,政策、保险政策、版权,例如,政策、保险政策、版权法等等。法等等。另一种更简单的分析方法,是所谓的非正式分另一种更简单的分析方法,是所谓的非正式分析。这种分析方法以用自然语言书写的需求陈述为析。这种分析方法以用自然语言书写的需求陈述为依据,把陈述中的依据,把陈述中的名词作为类对象的候选者名词作为类对象的候选者,用,用形容词作为
5、确定属性的线索形容词作为确定属性的线索,把,把动词作为服务(操动词作为服务(操作)的候选者作)的候选者。认真阅读上面给出的需求陈述,从陈述中找出认真阅读上面给出的需求陈述,从陈述中找出下列名词,可以把它们作为类对象的初步的候选下列名词,可以把它们作为类对象的初步的候选者:者:银行,自动取款机(银行,自动取款机(ATMATM),),系统,中央计算系统,中央计算机,分行计算机,柜员终端,网络,总行,分行,机,分行计算机,柜员终端,网络,总行,分行,软件,成本,市,街道,营业厅,储蓄所,柜员,软件,成本,市,街道,营业厅,储蓄所,柜员,储户,现金,支票,账户,事务,现金兑换卡,余储户,现金,支票,账
6、户,事务,现金兑换卡,余额,磁卡,分行代码,卡号,用户,副本,信息,额,磁卡,分行代码,卡号,用户,副本,信息,密码,类型,取款额,账单,访问。密码,类型,取款额,账单,访问。2 2筛选出正确的类对象筛选出正确的类对象接下来应该严格考察每个候选对象,从中去接下来应该严格考察每个候选对象,从中去掉不正确的或不必要的,仅保留确实应该记录其掉不正确的或不必要的,仅保留确实应该记录其信息或需要其提供服务的那些对象。信息或需要其提供服务的那些对象。筛选时主要依据下列标准,删除不正确或不筛选时主要依据下列标准,删除不正确或不必要的类对象:必要的类对象:(l l)冗余冗余 如果两个类表达了同样的信息,则应该
7、保留如果两个类表达了同样的信息,则应该保留在此问题域中最富于描述力的名称。在此问题域中最富于描述力的名称。以以ATMATM系统为例,应该去掉系统为例,应该去掉“用户用户”、“磁卡磁卡”、“副副本本”等冗余的类,仅保留等冗余的类,仅保留“储户储户”和和“现金兑换卡现金兑换卡”这两个类。这两个类。(2 2)无关)无关仅需要把与本问题密切相关的类对象放进目仅需要把与本问题密切相关的类对象放进目标系统中。标系统中。以以ATMATM系统为例,因此,应该去掉候选类系统为例,因此,应该去掉候选类“成本成本”、“市市”、“街道街道”、“营业厅营业厅”和和“储蓄所储蓄所”。(3 3)笼统)笼统 在需求陈述中常常
8、使用一些笼统的、泛指的名在需求陈述中常常使用一些笼统的、泛指的名词,虽然在初步分析时把它们作为候选的类对象词,虽然在初步分析时把它们作为候选的类对象列出来了,但是,要么系统无须记忆有关它们的信列出来了,但是,要么系统无须记忆有关它们的信息,要么在需求陈述中有更明确更具体的名词对应息,要么在需求陈述中有更明确更具体的名词对应它们所暗示的事务,因此,通常把这些笼统的或模它们所暗示的事务,因此,通常把这些笼统的或模糊的类去掉。糊的类去掉。以以ATMATM系统为例,应该去掉系统为例,应该去掉“银行银行”、“网络网络”、“系统系统”、“软件软件”、“信息信息”、“访问访问”等候选等候选类。类。(4 4)
9、属性)属性在需求陈述中有些名词实际上描述的是其他对在需求陈述中有些名词实际上描述的是其他对象的属性,应该把这些名词从候选类一一对象中象的属性,应该把这些名词从候选类一一对象中去掉。去掉。在在ATMATM系统的例子中,系统的例子中,“现金现金”、“支票支票”、“取款额取款额”、“账单账单”、“余额余额”、“分行代码分行代码”、“卡号卡号”、“密码密码”、“类型类型”等,实际上都应该等,实际上都应该作为属性对待。作为属性对待。(5 5)操作)操作 在需求陈述中有时可能使用一些既可作为名词,在需求陈述中有时可能使用一些既可作为名词,又可作为动词的词,应该慎重考虑它们在本问题中又可作为动词的词,应该慎
10、重考虑它们在本问题中的含义,以便正确地决定把它们作为类还是作为类的含义,以便正确地决定把它们作为类还是作为类中定义的操作。中定义的操作。(6 6)实现)实现在分析阶段不应该过早地考虑怎样实现目在分析阶段不应该过早地考虑怎样实现目标系统。因此,应该去掉仅和实现有关的候标系统。因此,应该去掉仅和实现有关的候选的类对象。选的类对象。在在ATMATM系统的例子中,应该暂时去掉系统的例子中,应该暂时去掉“事事务日志务日志”和和“通信链路通信链路”这两个类,在设计这两个类,在设计或实现时再考虑它们。或实现时再考虑它们。10.3.2 10.3.2 确定关联确定关联多数人习惯于在初步分析确定了问题多数人习惯于
11、在初步分析确定了问题域中的类对象之后,接下来就分析确定域中的类对象之后,接下来就分析确定类对象之间存在的关联关系。类对象之间存在的关联关系。两个或多个对象之间的相互依赖、相两个或多个对象之间的相互依赖、相互作用的关系就是关联。分析确定关联,互作用的关系就是关联。分析确定关联,能促使分析员考虑问题域的边缘情况,有能促使分析员考虑问题域的边缘情况,有助于发现那些尚未被发现的类助于发现那些尚未被发现的类&对象。对象。1 1初步确定关联初步确定关联在需求陈述中使用的描述性动词或动在需求陈述中使用的描述性动词或动词词组,通常表示关联关系。因此,在初词词组,通常表示关联关系。因此,在初步确定关联时,大多数
12、关联可以通过直接步确定关联时,大多数关联可以通过直接提取需求陈述中的动词词组而得出。通过提取需求陈述中的动词词组而得出。通过分析需求陈述,还能发现一些在陈述中隐分析需求陈述,还能发现一些在陈述中隐含的关联。含的关联。以以ATMATM系统为例,经过分析初步确定出系统为例,经过分析初步确定出下列关联:下列关联:(l l)直接提取动词短语得出的关联直接提取动词短语得出的关联 ATM ATM、中央计算机、分行计算机及柜中央计算机、分行计算机及柜员终端组成网络。员终端组成网络。总行拥有多台总行拥有多台ATMATM。分行提供分行计算机和柜员终端。分行提供分行计算机和柜员终端。储户拥有账户。储户拥有账户。柜
13、员输入针对账户的事务。柜员输入针对账户的事务。ATM ATM读现金兑换卡。读现金兑换卡。ATM ATM与用户交互。与用户交互。ATM ATM吐出现金。吐出现金。.ATM.ATM打印账单。打印账单。(2 2)需求陈述中隐含的关联)需求陈述中隐含的关联 总行由各个分行组成。总行由各个分行组成。分行保管账户。分行保管账户。总行拥有中央计算机。总行拥有中央计算机。系统维护事务日志。系统维护事务日志。系统提供必要的安全性。系统提供必要的安全性。储户拥有现金兑换卡。储户拥有现金兑换卡。(3 3)根据问题域知识得出的关联)根据问题域知识得出的关联 现金兑换卡访问账户。现金兑换卡访问账户。分行雇用柜员。分行雇
14、用柜员。2 2筛选筛选经初步分析得出的关联只能作为候选的关经初步分析得出的关联只能作为候选的关联,还需经过进一步筛选,以去掉不正确的联,还需经过进一步筛选,以去掉不正确的或不必要的关联。筛选时主要根据下述标准或不必要的关联。筛选时主要根据下述标准删除候选的关联:删除候选的关联:(1 1)已删去的类之间的关联。)已删去的类之间的关联。如果在分析确定类对象的过程中已经测如果在分析确定类对象的过程中已经测掉了某个候选类,则与这个类有关的关联也掉了某个候选类,则与这个类有关的关联也应该删去。应该删去。以以ATMATM系统为例,由于已经删去了系统为例,由于已经删去了“系统系统”、“网络网络”、“市市”、
15、“街道街道”、“成本成本”、“软件软件”、“事务日志事务日志”、“现金现金”、“营业厅营业厅”、“储蓄所储蓄所”、“账单账单”等候选类,因此,与这些类有关的下等候选类,因此,与这些类有关的下列八个关联也应该删去:列八个关联也应该删去:ATMATM、中央计算机、分行计算机及柜员终端组成中央计算机、分行计算机及柜员终端组成网络。网络。ATMATM设在主要街道上。设在主要街道上。分行分摊软件开发成本。分行分摊软件开发成本。系统提供必要的安全性。系统提供必要的安全性。系统维护事务日志。系统维护事务日志。ATMATM吐出现金。吐出现金。ATMATM打印账单。打印账单。柜员终端设在分行营业厅及储蓄所内。柜
16、员终端设在分行营业厅及储蓄所内。(2 2)与问题无关的或应在实现阶段考虑的关联)与问题无关的或应在实现阶段考虑的关联应该把处在本问题域之外的关联或与实现密切应该把处在本问题域之外的关联或与实现密切相关的关联删去。相关的关联删去。例,例,“系统处理并发的访问系统处理并发的访问”并没有标明对象并没有标明对象之间的新关联,它只不过提醒我们在实现阶段需要之间的新关联,它只不过提醒我们在实现阶段需要使用实现并发访问的算法,以处理并发事务。使用实现并发访问的算法,以处理并发事务。(3 3)瞬时事件)瞬时事件关联应该描述问题域的静态结构,而不应该是关联应该描述问题域的静态结构,而不应该是一个瞬时事件。一个瞬
17、时事件。例,例,“ATMATM读现金兑换卡读现金兑换卡”描述了描述了ATMATM与用户交与用户交互周期中的一个动作,它并不是互周期中的一个动作,它并不是ATMATM与现金兑换卡之与现金兑换卡之间的固有关系,因此应该删去。类似地,还应该删间的固有关系,因此应该删去。类似地,还应该删去去“ATMATM与用户交互与用户交互”这个候选的关联。这个候选的关联。(4 4)三元关联)三元关联三个或三个以上对象之间的关联,大多可以分三个或三个以上对象之间的关联,大多可以分解为二元关联或用词组描述成限定的关联。解为二元关联或用词组描述成限定的关联。例,例,“柜员输入针对账户的事务柜员输入针对账户的事务”可以分解
18、成可以分解成“柜员输人事务柜员输人事务”和和“事务修改账户事务修改账户”这样两个二这样两个二元关联。元关联。(5 5)派生关联)派生关联应该去掉那些可以用其他关联定义的冗余关联。应该去掉那些可以用其他关联定义的冗余关联。例如,在例如,在ATMATM系统的例子中,系统的例子中,“总行拥有多台总行拥有多台 ATM”ATM”实质上是实质上是“总行拥有中央计算机总行拥有中央计算机”和和“ATMATM与与中央计算机通信中央计算机通信”这两个关联组合的结果。而这两个关联组合的结果。而“分分行计算机维护账户行计算机维护账户”的实际含义是,的实际含义是,“分行保管账分行保管账户户”和和“事务修改账户事务修改账
19、户”。3 3进一步完善进一步完善应该进一步完善经筛选后余下的关联,通常从下述几应该进一步完善经筛选后余下的关联,通常从下述几个方面进行改进:个方面进行改进:(1 1)正名)正名好的名字是帮助读者理解的关键因素之一。好的名字是帮助读者理解的关键因素之一。(2 2)分解)分解为了能够适用于不同的关联,必要时应该分解以前确为了能够适用于不同的关联,必要时应该分解以前确定的类对象。定的类对象。例如,在例如,在ATMATM系统中,应该把系统中,应该把“事务事务”分解成分解成“远程事远程事务务”和和“柜员事务柜员事务”。(3 3)补充)补充发现了遗漏的关联就应该及时补上。发现了遗漏的关联就应该及时补上。例
20、如,在例如,在ATMATM系统中把系统中把“事务事务”分解成上述两类之后,分解成上述两类之后,需要补充需要补充“柜员输入柜员事务柜员输入柜员事务”、“柜员事务输进柜员终柜员事务输进柜员终端端”、“在在ATMATM上输入远程事务上输入远程事务”和和“远程事务由现金兑换远程事务由现金兑换卡授权卡授权”等关联。等关联。(4 4)标明阶数)标明阶数应该初步判定各个关联的类型,并粗略地确定关联的应该初步判定各个关联的类型,并粗略地确定关联的阶数。阶数。10103 33 3 划分主题划分主题在概念上把系统包含的内容分解成若干个在概念上把系统包含的内容分解成若干个主题(范畴)。主题(范畴)。应该按问题领域而
21、不是用功能分解方法来应该按问题领域而不是用功能分解方法来确定主题。此外,应该确定主题。此外,应该按照使不同主题内的按照使不同主题内的对象相互间依赖和交互最少的原则来确定主对象相互间依赖和交互最少的原则来确定主题。题。以以ATMATM系统为例,我们可以把它划分成系统为例,我们可以把它划分成“总行总行”、“分行分行”和和“ATM”ATM”等三个主题,这等三个主题,这三个主题的编号分别是三个主题的编号分别是l l、2 2和和3 3。10.3.4 10.3.4 确定属性确定属性属性是对象的性质,藉助于属性我们属性是对象的性质,藉助于属性我们能对类对象和结构有更深入更具体的能对类对象和结构有更深入更具体
22、的认识。认识。注意,在分析阶段不要用属性来表示注意,在分析阶段不要用属性来表示对象间的关系。对象间的关系。一般说来,确定属性的过程包括分析一般说来,确定属性的过程包括分析和选择两个步骤。和选择两个步骤。1 1分析分析属性的确定既与问题域有关,也和目属性的确定既与问题域有关,也和目标系统的任务有关。应该仅考虑与具体应标系统的任务有关。应该仅考虑与具体应用直接相关的属性,不要考虑那些超出所用直接相关的属性,不要考虑那些超出所要解决的问题范围的属性。在分析阶段不要解决的问题范围的属性。在分析阶段不要考虑那些纯粹用于实现的属性。要考虑那些纯粹用于实现的属性。2 2选择选择认真考察经初步分析而确定下来的
23、那认真考察经初步分析而确定下来的那些属性,从中删掉不正确的或不必要的属些属性,从中删掉不正确的或不必要的属性。通常有以下几种常见情况:性。通常有以下几种常见情况:(l l)误把对象当作属性误把对象当作属性如果某个实体的独立存在比它的值更重要,如果某个实体的独立存在比它的值更重要,则应把它作为一个对象而不是对象的属性。则应把它作为一个对象而不是对象的属性。例如,在邮政目录中,例如,在邮政目录中,“城市城市”是一个属性,而是一个属性,而在人口普查中却应该把在人口普查中却应该把“城市城市”当作对象。当作对象。(2 2)把限定误当成属性)把限定误当成属性限定是一种特殊的链属性。限定是一种特殊的链属性。
24、在在ATMATM系统的例子中,系统的例子中,“分行代码分行代码”、“账号账号”、“雇员号雇员号”、“站号站号”等都是限定词。等都是限定词。(4 4)误把内部状态当成了属性)误把内部状态当成了属性如果某个性质是对象的非公开的内部状态,则如果某个性质是对象的非公开的内部状态,则应该从对象模型中规掉这个属性。应该从对象模型中规掉这个属性。(5 5)过于细化)过于细化在分析阶段应该忽略那些对大多数操作都没有在分析阶段应该忽略那些对大多数操作都没有影响的属性。影响的属性。(6 6)存在不一致的属性)存在不一致的属性类应该是简单而且一致的。如果得出一些看起类应该是简单而且一致的。如果得出一些看起来与其他属
25、性毫不相关的属性,则应该考虑把该类来与其他属性毫不相关的属性,则应该考虑把该类分解成两个不同的类。分解成两个不同的类。经过筛选之后,得到经过筛选之后,得到ATMATM系统中各个类的属性,系统中各个类的属性,如图如图10105 5所示。所示。10103 35 5 识别继承关系识别继承关系可以使用两种方式建立继承(即归纳)关可以使用两种方式建立继承(即归纳)关系:系:(1 1)自底向上:抽象出现有类的共同性质泛化)自底向上:抽象出现有类的共同性质泛化出父类。例如,在出父类。例如,在ATMATM系统中,系统中,“远程事务远程事务”和和“柜员事务柜员事务”是类似的,可以泛化出父类是类似的,可以泛化出父
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 面向对象分析 讲稿 面向 对象 分析
限制150内