Rational Rose和UML可视化建模基础

为了成功地开发一个项目,你需要正确的过程、工具和符号(注释)。在本文中作者解释了UML是如何为你提供符号、Rational统一流程(Unified ProcESs)是如何为你提供正确的流程,以及Rational Rose是如何为你提供使项目成功的工具的。

什么是可视化建模

可视化建模(VISUAL MODELING)是利用围绕现实想法组织模型的一种思考问题的方法。模型对于了解问题、与项目相关的每个人(客户、行业专家、分析师、设计者等)沟通、模仿企业流程、准备文档、设计程序数据库来说都是有用的。建模促进了对需求的更好的理解、更清晰的设计、更加容易维护的系统。

模型通过过虑非本质的细节信息,成为描述复杂的问题或结构的本质的抽象(abSTraction),她使问题更容易理解了。抽象是一种允许我们处理复杂问题的基本能力。千百年以来,工程师、艺术家和工匠一直在实施某项工程之前,先建立模型提炼出它的设计方案。软件系统的开发也并不例外。为了建立复杂的系统,开发者必须抽象出系统的不同的视图,使用精确的符号建立模型,验证这些模型是否满足系统的需求,并逐渐添加细节信息把这些模型转变为实现(implementation)。

我们建立复杂系统的模型是因为我们没法理解整个系统。人理解复杂性的能力是有限的。这个观念可以在世界上的建筑中看到。如果你希望在后院中建立小屋,你可以立即开始建造;如果你希望建立新房子,你就可能需要一张蓝图了;如果你要建立摩天大楼,你就绝对需要一张蓝图。在软件的世界中这也是一样的。由源代码行或Visual BASic中设计的窗体担任主角为程序员提供的开发项目的全局视图是很微不足道的。构造模型允许设计师集中考虑项目中的组成部分如何交互的全局情况,而不会陷入每个组成部分的具体细节信息的泥沼中。

高度竞争的和不断改变的业务环境导致了复杂性不断增加,这为系统开发者带来了独特的挑战。模型帮助我们组织、形象化、理解和建立复杂的事物。它们在目前和未来都会帮助我们解决开发软件遭遇的各种挑战。

成功三角形

我经常使用图1所示的成功三角形来解释成功的项目所需要的组成部分。你需要所有的三个方面——符号、过程和工具。你可以学习一种符号,但是如果不知道如何利用它(过程),你可能会失败。你可能拥有强大的过程,但是如果不能沟通这些过程(符号),你也可能失败。最后,如果你不能记载自己的工作文档(工具),你也可能失败。


图1.成功三角形

符号的角色

符号在任何模型中都扮演着重要的部分——它是把过程连接在一起的“粘合剂”。符号有三种角色:

· 它作为传达决定的语言服务的,它不能明显地或者不能从代码自身中推理得到。

· 它提供的语义学对于捕捉所有重要的战略和战术决定都是足够丰富的。

· 它提供了一种具体的形式,足以供人们来思考和工具来操作。

统一的建模语言(UML)提供了非常健全的符号,它从分析的范围发展到了设计的范围了。一定的符号元素(例如类、联系、集合体、继承)都是在分析中引入的。其它的符号元素(例如保留实现的标识和属性)都是在设计中引入的。

UML的历史

在九十年代很多不同的方法学和它们的符号集都被引入市场中。其中最流行的三个是OMT(Rumbaugh)、BOoch和OOSE (Jacobson)。每种方法都有自己的价值和重点。OMT在分析方面强大,但是在设计方面比较弱。BOOch 1991在设计方面强大但是在分析方面比较弱。Jacobson在行为分析方面强大,但是在其它方面比较弱。

随着时间的推移,Booch写了他的第二本书,除了别的内容以外,他还采用了大量的Rumbaugh和 Jacobson提倡的好的分析技术。Rumbaugh出版了一系列文章,形成了我们所知道的OMT-2,它采用了Booch的大量的好的设计技术。这三种技术开始聚合在一起,但是各自仍然有自己独特的符号。由于符号对不同的人的意味着不同的事物,所以不同的符号的使用给市场带来了混乱。例如满圆形(filled circle)在OMT中是多样性标志,在Booch中却是集合标志。你可能听到过用术语“方法的战争”来描述这段时间——类到底是云形还是长方形的?哪个更好?

当符号都采用了统一的建模语言(UML)的时候“方法的战争”才结束了。“UML是一种用于具体说明、形象化、并记载开发中的面向对象系统的工作的语言。它表现了Booch、OMT和对象符号,以及大量的其它方法学(图2)的最佳观念的统一。通过统一这些面向对象方法使用的符号,统一的建模语言为基于广泛的用户经验基础形成的面向对象分析和设计领域中的事实上的标准提供了基础。”


图2. UML的组成

UML试图标准化分析和设计的工作:语义模型(semantic models)、语法符号(syntactic notation)和图表(DIagrAMs)。它的第一份公共草案(0.8版本)是在1995年10月引入的。公众和Ivar Jacobson的反馈都在后面的两个版本(1996年7月的0.9版本和1996年10月的0.91版本)中包括了。在1997年7月1.0版本被提供给对象管理工作组(OMG)以供标准化。额外的一些增强被集成到UML 1.1版本中,它在1997年9月被提交给OMG。在1997年11月,UML被OMG采用作为标准的建模语言。UML目前的版本是UML 1.4,并且正在朝UML 2.0的方向进展。你可以查看OMG的Web站点www.omg.org找到更多关于UML的信息。

过程的角色

成功地开发的项目满足或超过了客户的期望,它是用及时并节约的方式开发的,并且对于改变和适应是有弹性的。开发的生命周期必须促进创造和革新,同时开发过程必须被控制和衡量,以确保项目真正地完成了。“创造性对于所有良好构建的面向对象架构的技巧是基本的,但是允许开发者完全无限制地创造会使项目趋向于永远不会结束。同样地,当组织开发小组共同工作的时候纪律是必要的,但是太多的纪律将产生官僚作风,这会毁掉各种创新的尝试”。良好地组织的迭代和增加的生命周期在不影响创造性的情况下提供了必要的控制。

什么是迭代和增加的开发

在迭代和增加的生命周期中(图3),开发的进行就是一系列迭代,它们形成最终的系统。每种迭代包括下面的过程组成部分中的一个或多个:业务建模、需求、分析、设计、实现、测试和部署。在生命周期的开始,开发者不能假设所有的需求都是已知的;在所有的阶段中必然的改变都是预料中的。

这种类型的生命周期是一种减轻风险的过程。在生命周期的早期评估并区分了技术风险的优先次序,在每个阶段的开发中都会调整技术风险。风险被附加到每个阶段上,这样每个阶段的成功完成都会减轻附加到它上面的风险。其版本是按计划预定的,以确保最高的风险被最先处理。采用这种方式建立系统在生命周期的早期就暴露并减轻了系统的风险。这种生命周期方法的结果是风险更少,相关的投资更小。


图3.迭代和增加的开发

Rational Unified Process

通过使用Rational Unified Process可以支持对迭代和增加的生命周期的控制。它是解决那些集中于需求分析和设计的软件开发的技术方面和组织方面的问题的指导方针的扩展集合。

Rational Unified Process是沿着这两个方向构建的:

· 时间——把生命周期分割为阶段和迭代

· 过程组成部分——良好地定义的活动的特定工作集合的产品。

一个项目要获得成功的话,这两个方面都必须重视。

沿着时间维度构建项目包含了采用下面的基于时间的阶段:

· 初始——指定项目的版本

· 详尽细节——计划必要的活动和需要的资源;指明特征和设计架构

· 构建——用一系列增加的迭代建立产品

· 转换——为用户团体提供产品(制造、交付和训练)

沿着过程组成部分维度构建项目包含下面的活动:

· 业务建模——希望得到的系统能力和用户需求的认识

· 需求——拥有一组功能或非功能的需求的系统景象的叙述

· 分析和设计——在实现阶段系统如何被了解的描述

· 实现——结果将是可执行的系统的代码产品

· 测试——整个系统的验证

· 部署——系统的交付和对客户的用户训练


图4.过程组成步骤如何应用于某个基于时间的阶段

开发过程

典型情况下,过程组成部分维度中的每个活动都应用于基于时间的维度中的每个阶段。但是,特定的过程组成部分被应用的程度依赖于开发的阶段。例如,你可能决定在初始阶段做一次概念原型的校对,因此你做的事情比仅仅捕获需求要多一些(为了完善原型,你可能要执行分析、设计、实现和测试的事务)。分析过程的组成部分大部分在详尽细节阶段发生。但是,在这个阶段完善系统最初的少量迭代也是明智的。典型情况下,这些最初的少量迭代被用于验证为系统架构所作出的分析决定。

因此,你做的事情不仅仅是分析问题。在开发的构造阶段,系统由一组迭代完成。在任何类型的开发结构中,随着系统的构建,通常会出现一些事态,因此你仍然需要做一些分析。

图表应该是项目的生命周期的指导。其要点是在编写代码的时候,如果你仍然试图找出要建立什么样的系统,你可能就遇到麻烦了。你应该注意,测试应用于整个迭代过程中——你不能等待所有的代码完成后才检查它们是否能一起工作。

本文使用了Rational Unified Process的简化版本,它集中于使用UML来捕获和记载开发的初始阶段和详尽细节阶段中作出的决定。

Rational Rose工具

任何软件开发的方法都被某种工具最好地支持着。当我最初开始OO建模的时候,我的工具是纸张和铅笔,我想要更多的工具。现在市场中有了很多工具——从最简单的绘图工具到成熟的对象建模工具。本文使用的是Rational Rose。

Rational Rose产品家族被设计为为软件开发者提供完整的用于开发客户端/服务器、分布式企业和实时系统环境中满足实际业务需求的牢固的、高效率的解决方案的可视化建模工具集合。Rational Rose产品共享全体通用的标准,使得希望建立业务流程模型的非程序员和建立应用程序逻辑模型的程序员可以相互理解。Rational Rose工具的评估版可以通过Rational软件公司Web站点www.rational.com获取。

总结

可视化建模是利用围绕现实想法组织模型思考问题的一种方法。模型对于理解问题、沟通、建立企业模型、准备文档和设计程序和数据库都是有用的。建模促进了对需求的更好的理解、更好的设计和更容易维护的系统。符号在任何模型中都扮演着重要的部分——它是把过程粘合在一起的“粘合剂”。统一的建模语言提供了丰富的符号,它从分析中发展到设计中。

成功地开发的项目满足或超越客户的期望,它是用及时并节约的方式开发的,并且对改变和适应是有弹性的。开发生命周期必须促进创造和革新。良好的管理的迭代和增加生命周期提供了必要的控制,同时不会影响创造性。在迭代和增加的开发生命周期中,开发由一系列的迭代组成,它们将发展成最终的系统。每个迭代包含下面的过程组成部分中的一个或多个:业务建模、需求、分析、设计、实现、测试和部署。

通过使用Rational Unified Process可以支持对迭代和增加的生命周期的控制。它是解决那些集中于需求分析和设计的软件开发的技术方面和组织方面的问题的指导方针的扩充集合。

Rational Rose产品家族被设计为为软件开发者提供完整的用于开发客户端/服务器、分布式企业和实时系统环境中满足实际业务需求的牢固的、高效率的解决方案的可视化建模工具集合。

实验一 实验名称:业务建模 一、实验目的 1.熟悉业务建模内容。 2.掌握如何使用建模工具rational rose绘制业务模型图。 3.学习使用Microsoft Project对题目进行进度安排。 二、实验器材 1.计算机一台。 2.Rational Rose 工具软件。 三、实验内容 根据图书管理系统开发进度,在完成对系统的需求建模,得到用例模型后,应针对每个用例进行业务分析,说明其具体的业务流程,现系统分析部指派您完成该项任务。 要求: 1、创建业务用例模型。(参与者--用例)。 2、用活动图来描述系统核心业务过程。 3、创建业务对象模型。 四、实验步骤 1. 系统当前业务描述 …………………………… 2. 系统业务用例模型 ………………………….. 3. 核心业务用例的活动图 …………………………. 4. 系统业务对象模型 ………………………… 五、 实验心得 实验二 用例建模 一、 实验目的: 通过学生对提供的案例进行用例建模,熟练掌握用例建模技术。 二、主要实验仪器设备及环境 1. 计算机:安装有:操作系统为windows 2000,WindowsXP Professional; 2. 软件:National rose 三、实验内容: 1. 认真阅读案例的需求,根据其内容建立相应的用例模型; 2. 选择主要用例进行事件流分析,并把分析结果作为说明文档附在用例模型中; 四、实验步骤: 1. 系统参与者 2. 系统用例 3. 系统用例模型 4. 用例文档(主要用例) 五、实验心得 (对用例模型、用例的粒度、关系的理解) 实验三 顺序图 一、实验目的 1.理解顺序图的基本概念。 2. 掌握在Rational Rose中绘制交互图的操作方法。 3. 细化用例文档中的事件流,绘制顺序图。 二、实验器材 1.计算机一台。 2.Rational Rose 工具软件。 三、实验内容 通过对系统动态模型部分的学习,根据用例建模阶段的用例图和用例文档,对对应的用例实现用顺序图来描述系统的动态特性。完成如下任务: 对选定系统中的主要用例进行动态建模(顺序图)。 四、实验步骤 1.在logic view中创建“分析模型”包,在该包中添加“用例实现”包,在“用例实现”包中添加跟踪关系图(类图),在跟踪关系图中描述用例与用例实现的关系。为系统中主要的用例实现添加顺序图。 如下图: 2.在logic view中分别添加三个包(构造型:layer):边界层、控制层、实体层。主要根据用例文档来识别分析类(边界类、控制类、实体类)。如下图: 3.对主要的用例实现,根据细化用例文档中的主要事件流。 ……………………………………… 4.结合用例实现中识别出来的分析类,绘制顺序图。如下图: ……………………………………… 五:实验心得: 实验四 系统分析类图 一、实验目的 1.识别分析类之间的关系、类的属性和操作。 2.使用ROSE软件构建系统的分析类图。 二、实验器材 1.计算机一台。 2.Rational Rose 工具软件。 三、实验内容 根据***系统开发进度,在完成对系统的需求建模,得到用例模型后,应针对每个用例进行分析,识别出分析类,识别类的属性和方法,构建每个用例的VOPC图,综合所有用例的VOPC图,构建系统的分析类图 要求: 1、针对每个用例实现构建其VOPC图 2、综合所有VOPC图,构建系统的分析类图 四、实验步骤 1. 对每个用例实现识别分析类,根据需求、常识识别类的属性,根据交互图识别类的方法,在每个用例实现下创建一个类图,命名为 **用例的VOPC图(借书用例VOPC) 2. 综合所有VOPC图,在系统分析包中创建一个类图,命名为系统分析类图 3. 通过用例实现顺序图中的消息映射出分析类的操作(如下图)。 ……………………………………. 4. 根据用用例文档映射出类的属性(如下图)。 ……………………………………….. 五、实验总结 实验五 实验名称:子系统和接口 一、实验目的 1.基于分析阶段的BCE架构,抽取子系统。 2.根据包设计原则,对系统组织结构进行设计 。 二、实验器材 1.计算机一台。 2.Rational Rose 工具软件。 三、实验内容 根据指定系统的开发进度,已经完成对系统用例分析,应用BCE架构构建了系统的组织结构。本次实验主要根据抽取子系统的方法设计子系统、子系统接口,然后根据打包原则重构系统组织结构 要求: 1、抽取子系统,设计相应接口 2、利用包图设计系统架构 四、实验步骤 1. 抽取子系统系统是一种特殊的包,采用构造型《subsystem》扩展包的寓意,子系统内部是完全封装的,子系统提供接口对外服务。  你抽取子系统是依据什么角度(从那几个方面收取子系统?教材P263) ………文字描述子系统及抽取角度…………………… 2. 接口设计 接口是子系统对外提供的服务。接口采用构造型《interface》通过对类进行扩展表示 ……………子系统和接口的关系及几口中的操作,如P262 8-11图…….. 3. 更新软件架构 …………系统架构更新后的包图,如图8-17………………. 五、 实验心得 实验四 (系统静态模型)分析类图 一、实验目的 1.识别分析类、关系、类的属性和操作。 2.使用UML工具软件构建系统的分析类图。 二、实验器材 1.计算机一台。 2.Rational Rose 工具软件。 三、实验内容 根据***系统开发进度,在完成对系统的需求建模,得到用例模型后,应针对每个用例进行分析,识别出分析类,识别类的属性和方法,构建每个用例的VOPC图,综合所有用例的VOPC图,构建系统的分析类图 要求: 1、针对每个用例实现构建其VOPC图 2、综合所有VOPC图,构建系统的分析类图 3、根据顺序图为类添加操作 4、根据需求和用例文档为类添加属性 四、实验步骤 1. 对每个用例实现识别分析类,根据需求、常识识别类的属性,根据交互图识别类的方法,在每个用例实现下创建一个类图,命名为 **用例的VOPC图(借书用例VOPC) 1) 添加VOPC图 2) 打开vopc图,把该用例中的边界类、控制类、实体类拖入其中,并建立关系 2. 通过用例实现顺序图中的消息映射出分析类的操作(如下图)。 把每个类收到的消息映射为该类的一个操作。下面以申请边界类为例: 3. 根据用用例文档映射出类的属性(如下图)。 1) 打开某个类的规格说明,选择“属性”选项卡,在编辑窗口中点击鼠标右键,在菜单中“Insert”,可以为类添加属性 . 2) 例: 4. 综合所有的VOPC图,创建完整的系统分析类图 1) 在分析模型包下添加一个类图:命名为系统分析类图 2) 打开系统分析类图,把边界类包、控制类包、实体类包中的所有类拖入系统分析类图中,由于类的属性和操作、类之间的关系已经在每个类图中已经描述,所以在系统分析类图中会自然体现出来。 五、实验总结
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值