欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    需求分析师培训Day02.ppt

    • 资源ID:2340729       资源大小:6.34MB        全文页数:232页
    • 资源格式: PPT        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    需求分析师培训Day02.ppt

    需求分析师培训,Day02,中程在线信息产业培训网,Agenda,需求分析最佳实践需求建模最佳实践用例驱动的需求过程实践,中程在线信息产业培训网,Agenda,需求分析最佳实践需求建模最佳实践用例驱动的需求过程实践,需求分析是需求工程中的核心,中程在线信息产业培训网,需求分析回顾,所谓分析是指通过对问题域的研究,获得对该领域特性及存在于其中(需要解决)的问题特性的透彻理解并用文档说明分析方法:结构化分析法、面向对象分析法、面向问题域分析法需求分析与需求捕获是交替进行的需求分析的结果将通过建模、规格说明书编写的方式文档化,中程在线信息产业培训网,需求分析最佳实践 1,定义系统边界:评估原始需求,定义将要开发的系统的边界;确定哪些是系统需求,哪些是和系统相关的操作过程的需求,哪些是在系统范围之外的需求 主要效益:消除不必要的需求 引入成本:低 应用成本:低 实施指南:询问某项需求是否是基于不完整的或者不可靠的信息做出的?某项需求的实现是否需要在系统已定义的数据库之外的信息?某项需求是否和系统的核心功能相关?某项需求是否牵涉到系统之外的功能或者设备的性能?,中程在线信息产业培训网,需求分析最佳实践 2,使用校验表进行需求分析:根据经验开发需求问题校验表,并将其用于需求的系统化分析,每一项需求都应按照校验表进行分析。主要效益:更快、更完整地进行需求分析 引入成本:低-中 应用成本:低 实施指南:校验表不超过10项草率设计:该需求包括不成熟设计或实现信息吗?组合需求:该需求是单独的需求还是可以细分为多个需求?多余需求:该需求只是系统的修饰,还是真正必需?使用非标准硬件:必须使用非标准的硬件还是软件?符合业务目标:符合在需求文档开始处定义的业务目标?需求多义性:不同人是否可以从不同方式来理解?需求可实现性:基于当前技术,该需求可实现吗?需求可测试性:是否能够判断系统是否符合需求,中程在线信息产业培训网,需求分析最佳实践 3,使用软件支持协商:鼓励使用电子邮件来交换需求信息并且进行需求协商;也可以使用BBS、即时通信、群件系统来进行沟通与协商。主要效益:需求问题的更快解决 引入成本:低-中 应用成本:低-中 实施指南:电子邮件需指派一个问题管理人员,负责跟踪问题的提出、传递、回应和达成解决方案;BBS方案需要限制讨论的长度;群件方案需要事行定义好需求管理项的结构,中程在线信息产业培训网,需求分析最佳实践 4,对冲突和冲突解决方案做好计划:任何需求集中都会有冲突、重叠和遗漏问题,应该安排会议讨论这些需求并解决分析过程中发现的问题。主要效益:需求问题的更快解决 引入成本:低 应用成本:低 实施指南:会议是解决需求冲突最快的方式,应聚焦于解决突出的需求问题;电子信息交换也是可取的方式之一;会议通常包括叙述阶段、讨论阶段和决策阶段;分析的结果要发给所有与会者,中程在线信息产业培训网,需求分析最佳实践 5,需求分级:每一项需求都应该标上优先级,以反映它们对项目相关人员的重要性和对整个系统成功与否的重要性。主要效益:关注最重要的需求 引入成本:低 应用成本:低 实施指南:在需求捕获阶段就标明优先级是最理想的;通常需要进行了初始的分析工作才可能分配优先级;优先级的分配要由需求分析人员和项目相关人员共同完成;优先级不应太多,如必须的、有用的、希望的,中程在线信息产业培训网,需求分析最佳实践 6,使用多维方法进行需求分类:应对需求进行分类以便标记相关的需求,不必将单个需求只归到一个类,可以派生出多种分类方法。主要效益:有助于发现需求重叠和冲突 引入成本:低-中 应用成本:中 实施指南:可用系统、用户界面、数据库、通信、安全来进行分类;建议最多有56个分类;决定分类后,应把每个需求都和一到多个关键词关联起来;分类完成后,可以抽取很多组具有相同分类的需求进行比较和分析,中程在线信息产业培训网,需求分析最佳实践 7,使用交互矩阵发现冲突与重叠:交互矩阵的每一行和每一列都代表一项需求,每一个元素都用来表示对应的需求是否冲突、重叠或者独立 主要效益:揭示需求重叠和冲突 引入成本:低 应用成本:中-高 实施指南:创建交互矩阵最简单的方法是使用电子表格程序,在首行、首列均标上需求标识符;然后如果需求冲突填入1、重叠填入1000,独立则填0;这样只需要用求和的方式来统计出各种数目;通常需求不应超过200条,中程在线信息产业培训网,需求分析最佳实践 8,评估需求风险:对每一项需求或者一系列相关的需求进行风险分析,指出在实现需求过程中可能会发生的问题、这些问题发生的机率及其影响。主要效益:标识有问题的需求 引入成本:中 应用成本:中 实施指南:应考虑的风险主要有性能风险、安全风险、过程风险、实现技术风险、数据库风险、日程风险、外部风险、稳定风险,中程在线信息产业培训网,Agenda,需求分析最佳实践需求建模最佳实践用例驱动的需求过程实践,需求建模是表述需求的关键手段,中程在线信息产业培训网,讨论,在你的实践中是否建模?如果有建模,那么主要建哪些模型?有什么体会?如果没有建模,主要的原因是什么?,中程在线信息产业培训网,模型是对现实的简化,中程在线信息产业培训网,建模的目的与原则,帮助我们按照实际情况或按我们需要的样式对系统进行可视化;提供一种详细说明系统的结构或行为的方法;给出一个指导系统构造的模板;对我们所做出的决策进行文档化 仅当需要模型时,才构建它 选择要创建什么模型对如何动手解决问题和如何形成解决方案有着意义深远的影响;每一种模型可以在不同的精度级别上表示;最好的模型是与现实相联系的;单个模型是不充分的。对每个重要的系统最好用一组几乎独立的模型去处理。,中程在线信息产业培训网,系统建模最佳实践 1,开发互补的模型:在单个模型中包含所有的系统规格说明信息是难以实现的,因为这样的系统将会特别复杂,不可能读懂,因此应该创建多个系统模型。主要效益:揭示规格说明中的错误和不一致 引入成本:低-中 应用成本:中 实施指南:通常会开发数据处理模型(DFD)、组合模型(E-R)、分类模型(类图)、刺激-响应模型(状态图、活动图)、过程模型等;选择什么模型取决于要说明的信息类型、模型的读者、模型开发者的技能、CASE工具,中程在线信息产业培训网,系统建模最佳实践 2,系统环境建模:为了理解需求,应该就系统环境开发一个或多个模型,应该说明和本系统的接口和其他系统,以使用可能会使用本系统的业务过程。主要效益:记录必须说明接口的外部系统 引入成本:低 应用成本:低 实施指南:环境模型就是系统的使用语境模型,应包括和本系统直接交互的其他系统、可能和本系统共存并发生交互的系统、系统所在的业务过程。,中程在线信息产业培训网,系统建模最佳实践 3,系统体系结构建模:每次都应该开发系统的体系结构模型,用来说明系统是如何分解成子系统,还应解释子系统之间的通信。主要效益:有助于划分系统需求 引入成本:低-中 应用成本:低 实施指南:常用的体系结构模型包括客户机-服务器系统、分层系统、基于共享库通信的系统、管道系统,中程在线信息产业培训网,系统建模最佳实践 4,用标准化方法进行系统建模:标准化方法是一种系统分析和设计方法,包括定义、开发和确认系统模型过程中用到的表示法、指南和规则。主要效益:使用标准的方式书写系统模型 引入成本:中-高 应用成本:中 实施指南:包括过程化(结构化)方法、面向对象方法,其主要包括一组推荐的系统模型和相应的开发该模型的表示法、一组建模规则、一组关于创建高质量系统模型的指南、一份描述、一些报告。,中程在线信息产业培训网,系统建模最佳实践 5,使用数据字典:系统建模中使用的名字都应当记录在数据字典中,它是一份由计算机维护的名字列表以及相关的信息。主要效益:避免名字重复使用和误解 引入成本:中 应用成本:低 实施指南:进行数据字典的至少应包括模型中实体的名字、名字的别名及变化、实体类型、为何引入模型、针对实体的约束、指向相关实体的链接;数据字典必须由一台服务器维护,开发人员本机要与服务器经常实现同步,中程在线信息产业培训网,系统建模最佳实践 6,记录项目相关人员需求和系统模型之间联系:记录项目相关人员用自然语言描述的需求和说明这个系统的具体模型之间的关系。主要效益:便列发现受变更影响的需求和模型 引入成本:低 应用成本:中,中程在线信息产业培训网,UML基础,中程在线信息产业培训网,UML发展历程,中程在线信息产业培训网,UML特性与发展现状,UML是一种Language(语言)UML是一种Modeling(建模)LanguageUML是Unified(统一)Modeling Language已进入全面应用阶段的事实标准应用领域正在逐渐扩展,包括嵌入式系统建模、业务建模、流程建模等多个领域成为“产生式编程”的重要支持技术:MDA、可执行UML等,中程在线信息产业培训网,为什么使用UML建模,UML是一种统一的、标准化的建模语言 UML是一种应用面很广泛的建模语言,中程在线信息产业培训网,草图和蓝图,蓝图一般是指采用CASE工具绘制的、正式的、规范的UML模型 草图则通常是指手工绘制的、规范度较低的在纸张的UML模型 大胆地绘制草图,尽可能基于草图进行讨论。对于局部的、重要性不高的、共享范围较小的UML模型,直接将草图扫描到电脑存档即可;对于全局的、重要性高的、高度共享的,在草图的基础上用CASE工具绘制成为正式的蓝图,并将其纳入统一的模型管理中,中程在线信息产业培训网,谁应该建模,业务建模:以领域专家为主,需求分析人员是主力,系统分析员、架构师可参与需求模型:以需求分析人员为主,系统分析员是主力,领域专家提供指导,架构师和资深开发人员参与设计模型:高层设计模型以架构师为主,系统分析员从需求方面提供支持,资深开发人员从技术实现方面提供支持。详细设计模型则以资深开发人员为主,架构师提供指导。实现模型:以资深开发人员(设计人员)为主,架构师提供总体指导。数据库模型:以数据库开发人员为主,架构师提供指导,资深开发人员(设计人员)予以配合。,中程在线信息产业培训网,常见认识误区,UML是一种方法论UML就是一堆图形UML只能够应用于面向对象开发中UML就是Rose里的符号UML的学习周期很长、很复杂,中程在线信息产业培训网,UML的组成,基本构造块:也就是建模元素,是模型的主体UML规则:也就是支配基本构造块如何放在一起的规则公共机制:运用于整个UML模型中的公共机制、扩展机制,中程在线信息产业培训网,事物构造块,事物构造块是对模型中最具有代表性的成分的抽象 结构事物:UML中的名词,它是模型的静态部分,描述概念或物理元素。行为事物:UML中的动词,它是模型中的动态部分,是一种跨越时间、空间的行为。分组事物:UML中的容器,用来组织模型,使模型更加的结构化。注释事务:UML中的解释部分,和代码中的注释语句一样,是用来描述模型的。,中程在线信息产业培训网,面向对象视角下的世界,首先建立反应现实世界中不同事物的“构造块”,然后确定“构造块”之间的“关系”,再确定各个构造块的属性和“行为”。这样,在软件系统中就可以模拟现实世界的“构造块”之间的交互与协作 面向对象软件开发的核心思想就是高内聚(封装)、低耦合(消息驱动),使用简洁的接口拼合简单的部件,中程在线信息产业培训网,结构事物,类(class)和对象(object)接口(interface)主动类(active class)用例(use case)协作(collaboration)构件(component)节点(node),中程在线信息产业培训网,类和对象,类是对一组具有相同属性、相同操作、相同关系和相同语义的对象的抽象 UML中类是用一个矩形表示的,它包含三个区域,最上面是类名、中间是类的属性、最下面是类的方法 对象则是类的一个实例,中程在线信息产业培训网,接口,接口是描述某个类或构件的一个服务操作集,中程在线信息产业培训网,主动类,主动类实际上是一种特殊的类。引用它的原因,实际上是在开发中需要有一些类能够起到启动控制活动的作用 主动类是指其对象至少拥有一个进程或线程,能够启动控制活动的类,中程在线信息产业培训网,用例与协作,用例是著名的大师Ivar Jacobson首先提出的,现已经成为了面向对象软件开发中一个需求分析的最常用工具 用例实例是在系统中执行的一系列动作,这些动作将生成特定执行者可见的价值结果。一个用例定义一组用例实例。协作定义了一个交互,它是由一组共同工作以提供某协作行为的角色和其他元素构成的一个群体。对于某个用例的实现就可以表示为一个协作,中程在线信息产业培训网,构件,在实际的软件系统中,有许多要比“类”更大的实体,例如一个COM组件、一个DLL文件、一个JavaBeans、一个执行文件等等。为了更好地对在UML模型中对它们进行表示,就引入了构件(也译为组件)构件是系统设计的一个模块化部分,它隐藏了内部的实现,对外提供了一组外部接口。在系统中满足相同接口的组件可以自由地替换,中程在线信息产业培训网,节点,为了能够有效地对部署的结构进行建模,UML引入了节点这一概念,它可以用来描述实际的PC机、打印机、服务器等软件运行的基础硬件 节点是运行时存在的物理元素,它表示了一种可计算的资源,通常至少有存储空间和处理能力,中程在线信息产业培训网,行为事物,交互(interaction):是在特定语境中,共同完成某个任务的一组对象之间交换的信息集合 交互的表示法很简单,就是一条有向直线,并在上面标有操作名 状态机(state machine):是一个对象或交互在生命周期内响应事件所经历的状态序列 在UML模型中将状态画为一个圆角矩形,并在矩形内写出状态名称及其子状态,中程在线信息产业培训网,分组事物,对于一个中大型的软件系统而言,通常会包含大量的类,因此也就会存在大量的结构事物、行为事物,为了能够更加有效地对其进行整合,生成或简或繁、或宏观或微观的模型,就需要对其进行分组。在UML中,提供了“包(Package)”来完成这一目标,中程在线信息产业培训网,注释事物,结构事物是模型的主要构造块,行为事物则是补充了模型中的动态部分,分组事物而是用来更好地组织模型,似乎已经很完整了。而注释事物则是用来锦上添花的,它是用来在UML模型上添加适当的解释部分,中程在线信息产业培训网,关系构造块关联关系,关联(Association)表示两个类之间存在某种语义上的联系。关联关系提供了通信的路径,它是所有关系中最通用、语义最弱的。在UML中,使用一条实线来表示关联关系 在关联关系中有两种比较特殊的关系:聚合和组合 聚合关系:聚合(Aggregation)是一种特殊形式的关联。聚合表示类间的关系是整体与部分的关系 如果发现“部分”类的存在,是完全依赖于“整体”类的,那么就应该使用“组合”关系来描述,中程在线信息产业培训网,关系构造块其他关系,泛化关系描述了一般事物与该事物中的特殊种类之间的关系,也就是父类与子类之间的关系。实现关系是用来规定接口和实现接口的类或组件之间的关系。接口是操作的集合,这些操作用于规定类或组件的服务。扩展表示将一个构造型附加到一个元类上,使得元类的定义中包括这个构造型。有两个元素X、Y,如果修改元素X的定义可能会引起对另一个元素Y的定义的修改,则称元素Y依赖于元素X。,中程在线信息产业培训网,UML规则,命名:也就是为事物、关系和图起名字。和任何语言一样,名字都是一个标识符 范围:与类的作用域相似,包括所有者作用域和目标作用域两类 可见性:,中程在线信息产业培训网,公共机制规格描述,在图形表示法的每个部分后面都有一个规格描述(也称为详述),它用来对构造块的语法和语义进行文字叙述。这种构思,也就使可视化视图和文字视图的分离:,中程在线信息产业培训网,公共机制UML修饰与通用划分,在为了更好的表示这些细节,UML中还提供了一些修饰符号,例如不同可视性的符号、用斜体字表示抽象类 UML通用划分:1)类与对象的划分:类是一种抽象,对象是一个具体的实例 2)接口与实现的分离:接口是一种声明、是一个契约,也是服务的入口;实现则是负责实施接口提供的契约,中程在线信息产业培训网,UML扩展机制,构造型:在实际的建模过程中,可能会需要定义一些特定于某个领域或某个系统的构造块,中程在线信息产业培训网,UML扩展机制,标记值:则是用来为事物添加新特性的。标记值的表示方法是用形如“标记信息”的字符串 约束:是用来增加新的语义或改变已存在规则的一种机制(自由文本和OCL两种表示法)。约束的表示法和标记值法类似,都是使用花括号括起来的串来表示,不过它是不能够放在元素中的,而是放在相关的元素附近,中程在线信息产业培训网,UML定义的图,中程在线信息产业培训网,UML视图和图,中程在线信息产业培训网,UML图形分类,中程在线信息产业培训网,4+1视图,中程在线信息产业培训网,4+1视图,用例视图:它是最基本的需求分析模型,是可被最终用户看到的系统行为的用例组成。常用的模型包括用例图、交互图、状态图、活动图等。设计视图:又称为逻辑视图,以问题域的语汇组成的类和对象集合,用来描述类、接口、协作。常用的模型包括类图、交互图、状态图、活动图等。进程视图:形成系统并发与同步机制的线程和进程,也就是将可执行线程和进程作为活动类的建模,可理解为设计视图的一次执行实例。它使用的模型与设计视图类似,区别在于更侧重于主动类。,中程在线信息产业培训网,4+1视图,实现视图:对组成基于系统的物理代码的文件和组件进行建模,即装配与发布物理系统的构件和文件。常用的模型包括构件图、交互图、状态图、活动图。部署视图:包含了形成系统硬件拓扑结构的节点,也就是描述组件是如何物理地部署到一组物理的、可计算节点上的。常用的模型包括部署图、交互图、状态图、活动图。,中程在线信息产业培训网,开发过程,中程在线信息产业培训网,练习题,如果你想对一个类的用途进行简要描述,那么应该采用?请简要说明原因。A.标记值 B.规格描述 C.注释 D.构造型 请列举出三个以上UML中的事物构造块。说说适合用来表示“系统向用户提供的功能”的构造块是什么适用于模型管理的是哪张图?下图所示的符号表示的是什么?它是关系构造块还是事物构造块?,中程在线信息产业培训网,类图基础,中程在线信息产业培训网,理解面向对象思想,中程在线信息产业培训网,理解面向对象思想,每个对象都扮演了一个角色,并为其它成员提供特定的服务或执行特定的行为。在面向对象世界中,行为的启动是通过将“消息”传递给对此行为负责的对象来完成的;同时还将伴随着执行要求附上相关的信息(参数);而收到该消息的对象则会执行相应的“方法”来实现需求 用类和对象表示现实世界,用消息和方法来模拟现实世界的核心思想,中程在线信息产业培训网,如何用UML表示一个类,名称:每个类都有一个惟一的名称,通常采用CamelCase格式表示属性:是已被命名的类的特性,它描述该类实例中包含的信息 操作:是类所提供的服务,它可以由类的任何对象请求以影响其行为属性名和操作名也通常采用CamelCase格式表示,只不过首字母通常为小写。,中程在线信息产业培训网,如何阅读类图,先看清有哪些类,然后看看类之间存在的关系,并结合多重性来理解类图的结构特点以及各个属性和方法的含义,中程在线信息产业培训网,读图过程,读出类:图中共有7个类,Order、OrderItem、Customer、Consignee、DeliverOrder、Peddlery、Prodcut读出关系:从图中关系最复杂(也就是线最密集)的类开始阅读,本图中最复杂的就是Order类。1)OrderItem和Order之间是组合关系,根据箭头的方向可知Order包含了OrderItem。2)Order类和Customer、Consignee、DeliverOrder是关联关系。也就是说,一个订单和客户、收货人、送货单是相关的。,中程在线信息产业培训网,读图过程,多重性:用来说明关联的两个类之间的数量关系,中程在线信息产业培训网,读图过程理解方法和图,Order类,有两个方法:dispatch()和close(),从名字中可以猜出它们分别实现“分拆订单生成送货单”和“完成订单”。而在DeliveOrder()类中则有一个Close()方法,同理它应该表示“完成送货”。而在OrderItem中有一个stateChange()方法和deliverState,不难猜出它就是用来改变其“是否交给收货人”标志位的,中程在线信息产业培训网,读图过程理解方法和图,先调用Order的dispatch()方法,它将根据其包含的OrderItem中产品信息,来按供应商户分拆成若干个DeliverOrder。商户登录系统后就可以获取其DeliverOrder,并在执行完后调用close()方法。这时,就将调用OrderItem的stateChange()方法来改为其状态。同时再调用Order的close()方法,判断该Order的所有的OrderItem是否都已经送到了,如果是就将其真正close()掉,中程在线信息产业培训网,使用了更多建模元素的类图,中程在线信息产业培训网,辅助建模符号,导航箭号:类的实例之间只能沿着导航箭头的方向传递,在Order中可以获取其相应的Consignee,而从Consignee中是无法了解与其相关的Order的 角色名称:Customer端有一个“+Owner”字符串,这表示Customer扮演的角色是Owner,也能对关联进行命名,中程在线信息产业培训网,辅助建模符号,导出属性:是指可以根据其他值计算出来的特性,这种属性应在其名称前加上一个“/”符号。限定符:在Order和OrderItem之间的组合关系中,OrderItem这端多了个方框,写着“ProductId”。在UML中称为限定符,存在限定符的关联称为受限关联。它用来表示某种限定关系。在本例中说明:对于一张订单,每一种产品只能用一个订单项 约束:用来说明规则,xor职责:在类的属性栏中添加注释行表示,或增加了一个新的分栏,中程在线信息产业培训网,对象约束语言,环境与约束:每个OCL表达式都必须是针对某个元素的,因此在OCL表达式前必须说明它针对元素(这就称为环境)1)“context Object inv:”,其中Object是OCL表达式针对的建模元素名称;2)“Object”,其中Object是OCL表达式针对的建模元素名称。当声明了环境之后,就可以用self来引用它的变量,中程在线信息产业培训网,对象约束语言,子集约束:一致性:一个客户拥有零个或多个合同,发票是基于某个合同的,而一个客户将收到零张或多张发票 Invoice:self.contract.customer=self.customer,中程在线信息产业培训网,对象约束语言,异或关系:规定的取值范围:Rectangle:length0 and width0,中程在线信息产业培训网,用类图表示软件系统模型,领域模型是从面向对象视角看待现实世界的结果,也就是通过类图描述现实世界中各种事物的关系。分析模型和领域模型很相近,分析模型主要是针对软件系统,领域模型则更多偏重对业务领域的分析 设计模型则是在分析模型的基础上添加设计元素的结果。设计模型中的类的属性集更趋完善。,中程在线信息产业培训网,用类图表示数据库逻辑模型,从某种意义上说UML中的类图是E-R图的超集,E-R图只针对存储的数据,而类图则在些基础上,增加了行为建模的能力。在使用类图来表示E-R模型时,要注意遵循以下策略 将表示E-R模型的类,用UML的标准构造型“persistent”来表示;展开类的结构性细节,并加强关联和多重性分析;尽量消除循环关联、n-元关联,中程在线信息产业培训网,最常见的域建模错误,10.立即给关联指定多重度(multiplicity),确保每个关联都有明确的多重度。9.对名词和动词做过度的分析,而背离初衷。8.不对用例和时序图进行研究,就将操作分配给类。7.对象和类的通用程度越高,在其他项目中重用它们的可能性就越大。6.对于每个“一部分(part-of)”关联,就使用聚集还是组合(composition)而争论不休。,中程在线信息产业培训网,最常见的域建模错误,5.未对问题空间进行建模之前,就假定一种具体的实现策略。4.将类命名为难以理解的名称cPortMgrIntf),而不是直观的名称(如PortfolioManager)。3.直接进入到实现结构,如友元关系和参数化类。2.在域类和关系型数据库表之间建立一对一的映射。1.过早地执行“模式化”,这将导致根据同用户问题毫无关系的模式创建解决方案。,中程在线信息产业培训网,练习一,下图是一个仓库管理系统的类模型局部,其中IncomeOrder是指入库单,OrderItem是指入库中的每一项,Product则是产品信息。请指出模型中的错误,说明原因并改正错误,中程在线信息产业培训网,练习二,在描述“税务审批服务申请”时,它主要包含哪几个方面的内容?它有几种不同的类别?对于每一条流转记录,可能与几个“税务审批服务申请”相关?与几个处理人相关?,中程在线信息产业培训网,练习三,过早考虑实现阶段的内容,中程在线信息产业培训网,练习四,LoginManager,4.名字不直观8.太早定义类 的操作,中程在线信息产业培训网,练习五,4.名字不直观5.指定实现方 式EJB6.过早考虑聚 合或组合,Shopping Cart,中程在线信息产业培训网,练习六,2.与数据库表 一一对应8.过早分配类 的操作10关联多重性,Order,中程在线信息产业培训网,练习七,1.使用了设计模 式:Proxy;2.price、quan publisher可能 成为关联类;5.用了Java中 的Vector,中程在线信息产业培训网,练习七,中程在线信息产业培训网,练习八,5.使用了构造 型8.过早分配类 的操作,Candldate Order,Customer Review,中程在线信息产业培训网,练习九:根据下面描述绘制类图,这是一个“碟片出租店”使用的系统,它将用于计算每一位顾客的消费金额并打印报表。操作者告诉程序:顾客租了哪些影片、租期多长,程序便根据租凭时间和影片类型算出费用。影片分三类:普通片、儿童片和新片。除了计算费用,还要为常客计算机点数;点数会随着“租片种类是否为新片”而有所不同。,中程在线信息产业培训网,练习九解答 1,这是一个“碟片出租店”使用的程序,它将用于计算每一位顾客的消费金额并打印报表。操作者告诉程序:顾客租了哪些影片、租期多长,程序便根据租期和影片类型算出其消费金额。影片分三类:普通片、儿童片和新片。除了计算消费金额,还要为常客计算累积点数;累积点数会随着“租片种类是否为新片”而有所不同。,中程在线信息产业培训网,练习九解答 2,这是一个“碟片出租店”使用的程序,它将用于计算每一位顾客的消费金额并打印报表。操作者告诉程序:顾客租了哪些影片、租期多长,程序便根据租期和影片类型算出其消费金额。影片分三类:普通片、儿童片和新片。除了计算消费金额,还要为常客计算累积点数;累积点数会随着“租片种类是否为新片”而有所不同。,碟片出租店程序消费金额报表操作者顾客影片租期影片类型普通片儿童片新片累积点数,中程在线信息产业培训网,练习九解答 3,碟片出租店程序消费金额 报表操作者 顾客影片租期影片类型普通片儿童片新片累积点数,在系统外,系统本身,应该是每次“交易”属性,类!,在系统外,在系统外,但需记录,类!,类!,属性,影片的属性,类!,类!,类!,顾客的属性,报表,顾客,影片,普通片,儿童片,交易,新片,中程在线信息产业培训网,练习九解答 4,中程在线信息产业培训网,练习十,下图是小张绘制的一张关于网上商城用户管理的领域类图,但其中存在一些问题,请指出错误并说明理由,中程在线信息产业培训网,讨论,类图有什么用?用类图对领域进行建模时,主要的困难在于哪些方面?,中程在线信息产业培训网,交互图基础,中程在线信息产业培训网,交互的概念,一次交互就是指在特定语境中,为了实现某一个目标,而在一组对象之间进行交换的一组消息所表示的行为 在大多数的情况下,消息通常是指启动一个操作,或发送一个信号,以及创建或销毁一个对象 由一条有方向的直线,加上名称、参数(可选)和顺序组成,中程在线信息产业培训网,四种交互图,顺序图:强调消息时间顺序。首先把参与交互的对象放在图的上方,沿X轴方向排列。通常把发起交互的对象放在左边,较下级对象依次放在右边。然后,把这些对象发送和接收的消息沿Y轴方向按时间顺序从上到下放置。读者提供了控制流随着时间推移的清晰的可视化轨迹。协作图:在UML 2.0中称为通信图,强调的是参加交互的对象的组织。首先将参加交互的对象作为图的顶点,然后用这些对象之间的边线表示为图的边,再使用对象发送和接收的消息来修饰这些边。为读者提供了在协作对象结构组织的语境中观察控制流的一个清晰的可视化轨迹,中程在线信息产业培训网,四种交互图,定时图:采用了一种带数字刻度的时间轴来精确地描述消息的顺序,而不是像顺序图那样只是指定消息的相对顺序。而且它还允许可视化地表示每条生命线的状态变化,当需要对实时事件进行定义时,定时图就可以很好地满足 交互概述图:是交互图和活动图的混合物。你可以把交互概述图想像为活动图,只不过其中的活动被换成了一些小型顺序图;也可以把其想像为利用标明控制流的活动图分解过的顺序图,中程在线信息产业培训网,阅读顺序图,中程在线信息产业培训网,顺序图的主要元素,对象与角色:最顶上一排矩形框。在交互图中,参与交互的对象既可以是具体的事物,又可以是原型化的事物。作为具体的事物,一个对象代表现实世界中的某个东西。例如,aOrder作为类Order的一个实例,可以代表一个特定的订单;而如果作为一个原型化的事件,则aOrder可以代表类Order的任何一个实例。生命线与控制焦点:每个对象都有自己的生命线,对象生命线是一条垂直的虚线,用来表示一个对象在一段时间内存在。,中程在线信息产业培训网,顺序图的主要元素,消息:用来描述对象之间所进行的通信的,该信息带有对将要发生的活动的期望。当传送一个消息时,它所引起的动用是一个通过对计算过程的抽象而得到的可执行语句。消息分为五种:调用、返回、发送、创建和销毁调用:表示调用某个对象一个操作,中程在线信息产业培训网,顺序图的主要元素,返回:表示被调用的对象,向调用者返回一个值发送:发送是指向对象发送一个信号,和调用不同,它是一种事件,用来表示个实例间进行通信的异步激发机制 创建和销毁:就是创建和销毁一个对象。,中程在线信息产业培训网,顺序图的主要元素,顺序编号:整个消息的传递过程就形成了一个完整的序列,因此通过在每个消息的前面加上一个用冒号隔开的顺序号来表示其顺序。除了顺序编号之外,还可以采用嵌套方案:,中程在线信息产业培训网,顺序图的主要元素,循环与分支,中程在线信息产业培训网,读图小结,在dispatchForm(分发窗体)中,对于某个已支付的Order进行分发时,就会调用该订单(一个Order类的实例对象aOrder)的dispatch()方法。dispatch()方法将逐个调用该Order对应的所有OrderItem对象的getPeddleryId()方法还获取供应商ID(PeddleryId),而OrderItem对象则是通过其所对应的Product对象来的getPeddleryId()方法来获取供应商ID。,中程在线信息产业培训网,读图小结,当Order的实例对象aOrder得到返回的PeddleryId后,根据该值判断是否已经有相对应的DeliverOrder对象,如果没有就创建它(调用create(PeddleryId)),然后再将对应的Product添加到这个DeliverOrder对象中。否则就直接添加到相应的DeliverOrder对象中。,中程在线信息产业培训网,阅读协作(通信)图,中程在线信息产业培训网,协作图的主要元素,链:连接器,是用来表示对象之间的语义连接,一般而言,链是关联的一个实例(包括association、self、global、local等)。不过在UML 2中已经开始弱化它们的使用,因此除非必要,无需过多地考虑它们 消息编号:消息的编号有两种,一种是无层次编号,它简单直观;另一种是嵌套的编号,它更易于表示消息的包含关系迭代标记:用*号表示,表示循环,通常还有迭代表达式,用来说明循环规则,中程在线信息产业培训网,协作图的主要元素,监护条件:通常是用来表示分支的,也就是表示“如果条件为true,才发送消息”在通信图中使用监护条件一定要有所限制,通常应只列出主要的监护条件,否则会影响其阅读。如果需要,尽可能还是通过顺序图来表示,中程在线信息产业培训网,交互建模的准备工作,首先根据自己的喜好和实际的表现需要来选择顺序图或通信图。不过由于它们在语义上是等价的,因此可以绘制出一种,再通过建模工具来自动转换成另一种图 分析模型中的交互图彻重于分析类的职责分配和交互流程,而设计模型中的交互图则彻重于设计类的引入和实际方法的调用与流程控制 先确定参与交互的对象、对象之间的关系(通信图),然后确定对象间的消息交互流程(用同步调用、异步消息、返回消息表示),并利用交互片断(顺序图)或迭代标记及监护条件来表示循环和分支结构,中程在线信息产业培训网,交互建模Robustness分析,Robustness分析不是UML模型的一部分,它是一个强大的草图工具,是介于分析和设计之间的一种有效工具在Robustness分析中,将应用边界类、控制类和实体类从一个用例中抽取三类对象的方法:,中程在线信息产业培训网,Robustness分析从事件流开始,中程在线信息产业培训网,Robustness分析:寻找边界对象,图书管理员向系统发出“新增书籍信息”请求主窗口、“新增书籍信息”按钮系统要求图书管理员选择要新增的书籍是计算机类还是非计算机类书籍类别列表框。图书管理员做出选择后,显示相应界面,让图书管理员输入信息,并自动根据书号规则生成书号“新书信息录入”窗口及辅助的“提交”按钮,中程在线信息产业培训网,寻找控制对象与实体对象,根据事件流中的步骤5,以及扩展路径的描述,就可以在原图上增加相应的控制对象,得到更进一步的Robustness分析图,中程在线信息产业培训网,寻找控制对象与实体对象,新添两个逻辑:一是基本事件流中的步骤2、3要求根据用户选择的类别,自动获得书号;二是当书名重复性检查没有通过(有重名),则应返回要求其重输,中程在线信息产业培训网,构建交互模型,中程在线信息产业培训网,转成通信图,中程在线信息产业培训网,交互模型的应用,用例建模的目标是从使用者的角度来对系统进行梳理,Robustness分析则是对使用者的使用场景(一个用例的实例)进行的具体的分析,从而理解了系统需要做什么,并找出更多与解决方案相关的设计类。但更重要的是完整地捕获出这些类的行为、责任以及它们之间的交互,而这些正是系统运行的机制。而交互建模,正是要通过寻找对象之间的交互关系,从而进行“行为分配”。,中程在线信息产业培训网,交互模型的类型与演变,中程在线信息产业培训网,分析阶段的交互模型,针对用例图中的每个用例,并结合领域模型中的类,寻找分析类,并通过Robustness分析来理清业务逻辑流程,再用交互模型将其确定下来。同时这个阶段,不断地丰富分析模型,将新找到的类添加到类图中去在分析阶段我们主要关注于区分出边界对象、实体对象和控制对象,暂时不要考虑其具体的实现类 对于较复杂的用例而言,我们可以按上述的流程逐渐地进行分析、设计、实施;但对于比较简单的用例而言,也是可以直接从用例描述中导出设计阶段交互模型,中程在线信息产业培训网,分析阶段的交互模型之后,引入基础类:各种库函数、框架进行质量评审:1)低耦合2)高内聚3)效率4)完整性5)简单性优化类设计:设计模式与重构,中程在线信息产业培训网,设计阶段的交互模型,当在分析模型的基础上,通过引入基础类、优化类设计之后,必然会获得新的类模型(设计模型),因此就可能需

    注意事项

    本文(需求分析师培训Day02.ppt)为本站会员(仙人指路1688)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开