- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE 1
数据结构(C++版)
PAGE 25
软件工程导论(第五版)
第10章 面向对象分析
10.1面向对象分析的基本过程
不论采用哪种软件工程方法开发软件,需求分析的主要工作都是:理解需求、表达需求和验证需求,下面的图概括地表示了参照当前系统建立目标系统的过程。
图: 参照当前系统建立目标系统
面向对象分析(Object-Oriented Analysis,简称OOA)的关键就是识别出对象与类,并分析它们之间的关系,最终建立对象模型、动态模型和功能模型。
10.1.1 概述
系统分析员要善于学习、勇于实践,更重要的是一切从实际出发。
[注]“OOA就是抽取和整理用户需求并建立问题域精确模型的过程。”(P231)——这在一开始能做到吗?——扯蛋
3个子模型与5个层次
面向对象建模需建立包含系统的三个要素:1)静态结构(对象模型)、2)交互次序(动态??型)、3)数据交换(功能模型)。
建立系统模型的过程是一个迭代(iterations)式的自顶向下的求精过程。对于一个大型复杂系统来说对象模型一般由下述5个层次组成:
图10.2 复杂问题的对象模型的5个层次
其中主题层是指从一个更高(高于“类”)的抽象层次来描述对象模型(即从一个相当高的层次上描述总体模型),通过划分“主题”把一个复杂系统的对象模型分解成几个不同的概念范畴。
其实上述5个层次就是OOA中建立对象模型的5项主要工作:找出类和对象,识别结构(类或对象之间的关系),识别主题、定义属性、定义服务。我们知道动态模型和功能模型中都包含了对象模型中的操作,因此人们在定义每个类中的服务前,往往先建立起动态模型和功能模型,这样说来OOA大体上可按下列顺序进行:
(1)确定类和对象
(2)确定关联
(3)划分主题
(4)定义属性
(5)确定继承关系
(6)建立动态模型
(7)建立功能模型
(8)定义服务
需要注意地是在这里我们根本不强调顺序,更不是谈什么步骤。
10.2需求陈述
需求陈述的主要任务是准确地回答“系统必须做什么?”,而不是“系统应该怎么做?”
10.2.1书写要点
10.2.2例子
我们用“ATM系统”(ATM是Automatic Teller Machine的缩写,意即自动柜员机)的开发作为OOAOOD的实例。
图10.2ATM系统
10.3建立对象模型
10.3.1确定类与对象
1. 找出候选的类与对象(例:P236 ATM系统)
一般来说,大千世界中的客观事物可分为5类:
1)可感知的物理实体,如:飞机,汽车,房屋
2)人或组织的角色,如:教师,医生,计算机系,学生处
3)应该记忆的事件,如:飞行,演出,访问,交通事故
4)对象的相互作用,如:购买,结婚,纳税
5)概念,如:政策,刑法,泛化,集合
2. 筛选出正确的类与对象
我们需要确定的类与对象是:
应该记录的对象
需要它提供服务的对象
同时要关注下述6个方面:
冗余: 去掉冗余的类(如“用户”)
无关: 去掉无关的类(如“储蓄所”)
笼统: 去掉笼统的类(如“银行”)
属性: 区分属性和类(某个性质若具有很强的独立性应当作为“类”)
操作: 区分操作和类(本身具有属性且需独立存在的“操作”应当作为“类”)
实现: 忽略实现内容(应当去掉仅和实现有关的“类”,如“事务日志”)
10.3.2确定关联
对象之间的相互依赖、相互作用的关系就是关联。在分析的起始阶段,我们不必花过多的精力去区分关联和聚集,聚集不过是一种特殊的关联,是关联的一个特例。
1. 初步确定关联
通过分析动词词组我们可以得出大多数关联(例:P238 ATM系统)
2. 筛选
筛选时要关注下述5个方面:
1)已删去的类之间的关联也要删除
2)无关的或在实现阶段考虑的关联要删除
3)描述瞬时事件的关系不应作为关联(关联应该描述问题域的静态结构)
4)三个或三个以上对象的关联要作分解或描述成限定关联
5)冗余关联要删除
3. 进一步完善
完善时要关注下述4个方面:
1)正名:选择更明确的名字作为关联名
2)分解:分解已确定的类以适用关联
3)补充:及时补充遗漏关联
4)标明重数:但无需花过多精力
图10.3ATM系统原始的类图
10.3.3划分主题
按问题领域而不是用功能分解来高度概括主题
10.3.4确定属性
属性是类中所定义的数据,它表明了对象的性质。
一般来说,确定属性的过程
您可能关注的文档
最近下载
- 部队个人防护器材优质教案.doc VIP
- 2025年基于石油企业的价格管理新模式.pdf VIP
- 新教科版(2025版)六年级上册科学全册教案+单元测试卷 .pdf VIP
- 2024-2025新人教版初中数学七年级上册(全册)优秀ppt课件.pptx VIP
- 2025年陕西省综合评标评审专家库考试在线题库及答案.docx VIP
- 《T/CSPSTC 78-2021顶管法管道工程技术规程》.pdf
- 2025年甘肃省公路交通建设集团康略高速公路收费运营人员招聘71人笔试备考试题及答案解析.docx VIP
- 第一单元(核心素养目标教案)-统编版语文五年级上册.docx VIP
- 中考作文指导:中考作文审题课件.pptx
- 2023新能源风电生产指标体系.docx VIP
文档评论(0)